Assorted Windows procedures.
Include File: AfxNova/AfxWin.inc.
| Name | Description |
|---|---|
| AfxCommand | Returns command line parameters used to call the program. |
| AfxCommandLineCount | Returns the number of command line arguments used to call the program |
| AfxComputerName | Retrieves the NetBIOS name of the local computer. |
| AfxComputerNameDnsFullyQualified | Retrieves the fully qualified DNS name that uniquely identifies the local computer. |
| AfxComputerNameDnsHostname | Retrieves the DNS host name of the local computer. |
| AfxGetComputerNameDnsHostname | Retrieves the The DNS host name of the local computer. |
| AfxComputerNameNetBios | Retrieves the NetBIOS name of the local computer. |
| AfxExtractResource | Extracts resource data and returns it as a string. |
| AfxExtractResourceToFile | Extracts resource data and saves it to a file. |
| AfxGetAllMACAddresses | Populates a dynamic array of STRINGs with all the real MAC addresses of the system. |
| AfxGetAllPhysicalMACAddresses | Populates a dynamic array of STRINGs with all real MAC addresses (Ethernet/Wi-Fi). |
| AfxGetComputerName | Retrieves the NetBIOS name of the local computer. |
| AfxComputerNameDnsFullyQualified | Retrieves the fully qualified DNS name that uniquely identifies the local computer. |
| AfxGetComputerNameDnsHostname | Retrieves the The DNS host name of the local computer. |
| AfxComputerNameNetBios | Retrieves the NetBIOS name of the local computer. |
| AfxGetMACAddress | Retrieves the MAC address of a machine’s Ethernet card. |
| AfxGetMACAddressEx | Retrieves the MAC address of a machine’s Ethernet card. |
| AfxGetTempPath | Retrieves the path of the directory designated for temporary files. |
| AfxGetUserName | Retrieves the name of the user associated with the current thread. |
| AfxGetSystemWow64Directory | Retrieves the path of the system directory used by WOW64. |
| AfxGetWinDir | Retrieves the path of the Windows directory. |
| AfxGetWinErrMsg | Retrieves the localized description of the specified Windows error code. |
| AfxGetWindowsDirectory | Retrieves the path of the Windows directory. |
| AfxMsg | Displays an application modal message box. |
| AfxSystemWow64Directory | Retrieves the path of the system directory used by WOW64. |
| AfxTempPath | Retrieves the path of the directory designated for temporary files. |
| AfxUserName | Retrieves the name of the user associated with the current thread. |
| AfxWinDir | Retrieves the path of the Windows directory. |
| Name | Description |
|---|---|
| AfxChDir | Changes the current directory for the current process. |
| AfxCopyFile | Copies an existing file to a new file. |
| AfxCreateDirectory | Creates a new directory. |
| AfxCurDir | Retrieves the current directory for the current process. |
| AfxDeleteFile | Deletes the specified file. |
| AfxExeFileExt | Parses a path/filename and returns the extension portion of the path/file name. That is the last period (.) in the string plus the text to the right of it. |
| AfxExeFileName | Returns the file name of the program which is currently executing. |
| AfxExeFileNameX | Returns the file name and extension of the program which is currently executing. |
| AfxGetExeFullPath | Returns the complete drive, path, file name, and extension of the program which is currently executing. |
| AfxExePath | Returns the path of the program which is currently executing. The path has not a trailing backslash except if it is a drive, e.g. C:. |
| AfxExePathName | Returns the path of the program which is currently executing. The path has a trailing backslash. |
| AfxFileCopy | Copies an existing file to a new file. |
| AfxFileDateTime | Returns the file’s last modified date and time as Date Serial. |
| AfxFileExists | Searches a directory for a file or subdirectory with a name that matches a specific name (or partial name if wildcards are used). |
| AfxFileExt | Parses a path/filename and returns the extension portion of the path/file name. That is the last period (.) in the string plus the text to the right of it. |
| AfxFileName | Parses a path/filename and returns the file name portion. That is the text to the right of the last backslash () or colon (:), ending just before the last period (.). |
| AfxFileNameX | Parses a path/filename and returns the file name and extension portion. That is the text to the right of the last backslash () or colon (:). |
| AfxFileReadAllLines | Reads all the lines of the specified file into a safe array. |
| AfxFileScan | Scans a text file and returns the number of occurrences of the specified delimiter. |
| AfxFolderExists | Searches a directory for a file or subdirectory with a name that matches a specific name (or partial name if wildcards are used). |
| AfxFolderName | Returns a string containing the name of the folder for a specified path, i.e. the path minus the file name. |
| AfxGetCurDir | Retrieves the current directory for the current process. |
| AfxGetCurrentDirectory | Retrieves the current directory for the current process. |
| AfxGetDriveType | Determines whether a disk drive is a removable, fixed, CD-ROM, RAM disk, or network drive. |
| AfxGetExeFileExt | Parses a path/filename and returns the extension portion of the path/file name. That is the last period (.) in the string plus the text to the right of it. |
| AfxGetExeFileName | Returns the file name of the program which is currently executing. |
| AfxGetExeFileNameX | Returns the file name and extension of the program which is currently executing. |
| AfxGetExeFullPath | Returns the complete drive, path, file name, and extension of the program which is currently executing. |
| AfxGetExePath | Returns the path of the program which is currently executing. The path has not a trailing backslash except if it is a drive, e.g. C:. |
| AfxGetExePathName | Returns the path of the program which is currently executing. The path has a trailing backslash. |
| AfxGetFileCreationTime | Returns the time the file was created, in FILETIME format. |
| AfxGetFileExt | Parses a path/filename and returns the extension portion of the path/file name. That is the last period (.) in the string plus the text to the right of it. |
| AfxGetFileLastAccessTime | Returns the time the file was last accessed, in FILETIME format. |
| AfxGetFileLastWriteTime | Returns the time the file was last written to, truncated, or overwritten, in FILETIME format. |
| AfxFileLen | Returns the size in bytes of the specified file. |
| AfxGetFileName | Parses a path/filename and returns the file name portion. That is the text to the right of the last backslash () or colon (:), ending just before the last period (.). |
| AfxGetFileNameX | Parses a path/filename and returns the file name and extension portion. That is the text to the right of the last backslash () or colon (:). |
| AfxGetFileSize | Returns the size in bytes of the specified file. |
| AfxGetFileVersion | Retrieves the version of the specified file multiplied by 100, e.g. 601 for version 6.01. |
| AfxGetFolderName | Returns a string containing the name of the folder for a specified path, i.e. the path minus the file name. |
| AfxGetKnowFolderPath | Retrieves the path of an special folder. Requires Windows Vista/Windows 7 or superior. |
| AfxGetLongPathName | Retrieves the short path form of the specified path. |
| AfxGetPathFromProcessId | Retrieves the path of the executable file given its process identifier. |
| AfxGetPathName | Parses a path/filename and returns the path portion. That is the text up to and including the last backslash () or colon (:). |
| AfxGetShortPathName | Retrieves the short path form of the specified path. |
| AfxGetSpecialFolderLocation | Retrieves the path of an special folder. |
| AfxGetSystemDllPath | Retrieves the fully qualified path for the file that contains the specified module. |
| AfxGetSystemDrive | Retrieves the fully qualified path for the file that contains the specified module. |
| AfxGetSystemDirectory | Retrieves the path of the system directory. |
| AfxGetWinDir | Retrieves the path of the Windows directory. |
| AfxIsCompressedFile | Returns True if the specified file or directory is compressed; False if it is not. |
| AfxIsEncryptedFile | Returns True if the specified file or directory is encrypted; False if it is not. |
| AfxIsFolder | Returns True if the specified path is a folder; False if it is not. |
| AfxIsHiddenFile | Returns True if the specified path is a hidden file or directory; False if it is not. |
| AfxIsNormalFile | Returns True if the specified path is a normal file (a file that does not have other attributes set); False if it is not. |
| AfxIsNotContentIndexedFile | Returns TRUE if the specified file or directory is not to be indexed by the content indexing service; FALSE, otherwise. |
| AfxIsOfflineFile | Returns TRUE if the specified file file is not available immediately; FALSE, otherwise. |
| AfxIsReadOnlyFile | Returns True if the specified path is a read only file; False if it is not. |
| AfxIsReparsePointFile | Returns TRUE if the specified path is a file or directory that has an associated reparse point, or a file that is a symbolic link.; FALSE, otherwise. |
| AfxIsSparseFile | Returns TRUE if the specified path is a sparse file; FALSE, otherwise. |
| AfxIsSystemFile | Returns True if the specified path is a system file; False if it is not. |
| AfxIsTemporaryFile | Returns True if the specified path is a temporary file; False if it is not. |
| AfxKill | Deletes the specified file. |
| AfxLongPathName | Retrieves the short path form of the specified path. |
| AfxMakeDir | Creates a new directory. |
| AfxMkDir | Creates a new directory. |
| AfxMoveFile | Moves an existing file or a directory, including its children. |
| AfxName | Moves an existing file or a directory, including its children. |
| AfxPathFromProcessId | Retrieves the path of the executable file given its process identifier. |
| AfxPathName | Parses a path/filename and returns the path portion. That is the text up to and including the last backslash () or colon (:). |
| AfxRemoveDirectory | Deletes an existing empty directory. |
| AfxRemoveDir | Deletes an existing empty directory. |
| AfxRenameFile | Moves an existing file or a directory, including its children. |
| AfxRmDir | Deletes an existing empty directory. |
| AfxSaveIconToFile | Saves an icon to a file. |
| AfxSaveTempFile | Saves the contents of a string buffer in a temporary file. |
| AfxSetCurDir | Changes the current directory for the current process. |
| AfxSetCurrentDirectory | Changes the current directory for the current process. |
| AfxShortPathName | Retrieves the short path form of the specified path. |
| AfxSystemDllPath | Retrieves the fully qualified path for the file that contains the specified module. |
| AfxSystemDirectory | Retrieves the path of the system directory. |
| AfxSystemDrive | Retrieves the fully qualified path for the file that contains the specified module. |
| Name | Description |
|---|---|
| AfxCenterWindow | Centers a window on the screen or over another window. |
| AfxForceSetForegroundWindow | Brings the thread that created the specified window into the foreground and activates the window. |
| AfxGetSystemInfo | Retrieves information about the current system. |
| AfxGetTopEnabledWindow | Retrieves the handle of the enabled and visible window at the top of the z-order in an application. |
| AfxGetTopLevelParent | Retrieves the window’s top-level parent window. |
| AfxGetTopLevelWindow | Retrieves the window’s top-level parent or owner window. |
| AfxGetWindowBounds | Retrieves the bounds of a window without the drop shadows. |
| AfxGetWindowClassName | Retrieves the name of the class to which the specified window belongs. |
| AfxGetWindowClientHeight | Returns the height of the client area of window, in pixels. |
| AfxGetWindowClientRect | Retrieves the coordinates of a window’s client area. |
| AfxGetWindowClientWidth | Returns the width of the client area of a window, in pixels. |
| AfxGetWindowHeight | Returns the height of a window, in pixels. |
| AfxGetWindowLocation | Returns the location of the top left corner of the window, in pixels. |
| AfxGetWindowRect | Retrieves the dimensions of the bounding rectangle of the specified window. |
| AfxGetWindowSize | Gets the width and height of a window, in pixels. |
| AfxGetWindowText | Gets the text of a window. |
| AfxGetWindowTextLength | Gets the length of the text of a window. |
| AfxGetWindowWidth | Returns the width of a window, in pixels. |
| AfxGetWorkAreaHeight | Retrieves the height of the work area on the primary display monitor expressed in virtual screen coordinates. |
| AfxGetWorkAreaRect | Retrieves the coordinates of the work area on the primary display monitor expressed in virtual screen coordinates |
| AfxGetWorkAreaWidth | Retrieves the width of the work area on the primary display monitor expressed in virtual screen coordinates. |
| AfxMoveWindowForDpi | Changes the position and dimensions of the specified window. |
| AfxRedrawNonClientArea | Redraws the non-client area of the specified window. |
| AfxRedrawWindow | Redraws the specified window. |
| AfxSetWindowClientSize | Adjusts the bounding rectangle of a window based on the desired size of the client area. |
| AfxSetWindowClientSizeForDpi | Adjusts the bounding rectangle of a window based on the desired size of the client area. DPI aware. |
| AfxSetWindowIcon | Associates a new large icon with a window. |
| AfxSetWindowLocation | Sets the location of the top left corner of the window, in pixels. |
| AfxSetWindowLocationForDpi | Sets the location of the top left corner of the window, in pixels. DPI aware |
| AfxSetWindowPosForDpi | Sets the size of the specified window, in pixels. |
| AfxSetWindowSize | Sets the size of the specified window, in pixels. |
| AfxSetWindowSizeForDpi | Sets the size of the specified window, in pixels. DPI aware. |
| AfxSetWindowText | Sets the text of a window. |
| AfxShowWindowState | Sets the specified window’s show state. |
| Name | Description |
|---|---|
| AfxAddWindowExStyle | Adds a new extended style to the specified window. |
| AfxAddWindowStyle | Adds a new style to the specified window. |
| AfxGetWindowExStyle | Retrieves the extended window styles. |
| AfxGetWindowStyle | Retrieves the window styles. |
| AfxRemoveWindowExStyle | Removes an extended style from the specified window. |
| AfxRemoveWindowStyle | Removes a style from the specified window. |
| AfxSetWindowExStyle | Sets the extended style(s) of the specified window. |
| AfxSetWindowStyle | Sets the style(s) of the specified window. |
| Name | Description |
|---|---|
| AfxForceVisibleDisplay | Force visibility of an off-screen window. |
| AfxGetDisplayBitsPerPixel | Returns the color resolution, in bits per pixel, of the display device. |
| AfxGetDisplayFrequency | Returns the frequency, in hertz (cycles per second), of the display device in a particular mode. |
| AfxGetDisplayPixelsHeight | Returns the height, in pixels, of the current display device on the computer on which the calling thread is running. |
| AfxGetDisplayPixelsWidth | Returns the width, in pixels, of the current display device on the computer on which the calling thread is running. |
| AfxGetScreenColors | Returns the color resolution, in bits per pixel, of the display device. |
| AfxGetScreenHeight | Retrieves the height of the screen, in pixels. This function is virtualized for DPI. |
| AfxGetScreenRefreshDate | Returns the frequency, in hertz (cycles per second), of the display device in a particular mode. |
| AfxScreenWidth | Retrieves the width of the screen, in pixels. This function is virtualized for DPI. |
| AfxScreenColors | Returns the color resolution, in bits per pixel, of the display device. |
| AfxGetScreenRefreshDate | Returns the frequency, in hertz (cycles per second), of the display device in a particular mode. |
| AfxGetWorkArea | Retrieves the coordinates of the work area on the primary display monitor expressed in virtual screen coordinates. |
| AfxScreenHeight | Retrieves the height of the screen, in pixels. This function is virtualized for DPI. |
| AfxScreenWidth | Retrieves the width of the screen, in pixels. This function is virtualized for DPI. |
| AfxWorkArea | Retrieves the coordinates of the work area on the primary display monitor expressed in virtual screen coordinates. |
| Name | Description |
|---|---|
| AfxDoEvents | Processes pending Windows messages. |
| AfxForwardSizeMessage | Sends a WM_SIZE message to the specified window. |
| AfxPumpMessages | Processes pending Windows messages. |
| Name | Description |
|---|---|
| AfxGetControlHandle | Returns the handle of the control with the specified identifier. |
| AfxGetFormHandle | Finds the handle of the top-level window or MDI child window that is the ancestor of the specified window handle. |
| AfxGetHwndFromPID | Retrieves a window handle given it’s process identifier. |
| AfxPathFromWindowHandle | Retrieves the path of the executable file that created the specified window. |
| AfxGetPathFromWindowHandle | Retrieves the path of the executable file that created the specified window. |
| Name | Description |
|---|---|
| AfxBrowseForFolder | Displays a dialog box that enables the user to select a folder. |
| AfxChooseColorDialog | Displays the Windows choose color dialog. |
| AfxControlRunDLL | Launches control panel applications. |
| AfxOpenFileDialog | Creates an Open dialog box that lets the user specify the drive, directory, and the name of a file or set of files to be opened. |
| AfxSaveFileDialog | Creates a Save dialog box that lets the user specify the drive, directory, and name of a file to save. |
| AfxShowSysInfo | Displays the Windows Information System dialog. |
| Name | Description |
|---|---|
| AfxGetDpi | Retrieves the number of pixels per logical inch. |
| AfxGetDpiX | Retrieves the number of pixels per logical inch along the screen width. |
| AfxGetDpiY | Retrieves the number of pixels per logical inch along the screen height. |
| AfxGetMonitorHorizontalScaling | Returns the horizontal scaling of the monitor that the window is currently displayed on. |
| AfxGetMonitorVerticalScaling | Returns the vertical scaling of the monitor that the window is currently displayed on. |
| AfxGetMonitorLogicalHeight | Returns the logical height of the monitor that the window is currently displayed on. |
| AfxGetMonitorLogicalWidth | Returns the logical width of the monitor that the window is currently displayed on. |
| AfxIsDPIResolutionAtLeast | Determines if screen resolution meets minimum requirements in relative pixels. |
| AfxIsProcessDPIAware | Determines whether the current process is dots per inch (dpi) aware. |
| AfxIsResolutionAtLeast | Determines if screen resolution meets minimum requirements. |
| AfxLoadIconMetric | Loads a specified icon resource with a client-specified system metric. |
| AfxLogPixelsX | Retrieves the number of pixels per logical inch along the screen width. |
| AfxLogPixelsY | Retrieves the number of pixels per logical inch along the screen height. |
| AfxScaleRatioX | Retrieves the desktop horizontal scaling ratio. |
| AfxScaleRatioY | Retrieves the desktop vertical scaling ratio. |
| AfxScaleX | Scales an horizontal coordinate according the DPI (dots per pixel) being used by the operating system. |
| AfxScaleY | Scales an vertical coordinate according the DPI (dots per pixel) being used by the operating system. |
| AfxSetProcessDPIAware | Sets the current process as dots per inch (dpi) aware. |
| AfxUnscaleX | Unscales an horizontal coordinate according the DPI (dots per pixel) being used by the operating system. |
| AfxUnscaleY | Unscales a vertical coordinate according the DPI (dots per pixel) being used by the operating system. |
| AfxUseDpiScaling | Returns TRUE if the OS uses DPI scaling; FALSE otherwise. |
| Name | Description |
|---|---|
| AfxCreateFont | Creates a logical font. |
| AfxGetFontHeight | Returns the logical height of a font given its point size. |
| AfxGetFontPointSize | Returns the point size of a font given its logical height. |
| AfxGetWindowFont | Retrieves the font with which the window or control is currently drawing its text. |
| AfxGetWindowFontInfo | Retrieves information about the font being used by a window or control. |
| AfxGetWindowsFontInfo | Retrieves information about the fonts used by Windows. |
| AfxGetWindowsFontPointSize | Retrieves the point size of the fonts used by Windows. |
| AfxModifyFontFaceName | Modifies the face name of the font of a window or control. |
| AfxModifyFontHeight | Modifies the height of the font used by a window of control. |
| AfxModifyFontSettings | Modifies settings of the font used by a window of control. |
| AfxSetWindowFont | Sets the font that a control is to use when drawing text. |
| Name | Description |
|---|---|
| AfxClearClipboard | Clears the contents of the clipboard. |
| AfxGetClipboardData | Retrieves data from the clipboard in the specified format. |
| AfxGetClipboardText | Returns a text string from the clipboard. |
| AfxSetClipboardData | Places data on the clipboard in a specified clipboard format. |
| AfxSetClipboardText | Places a text string into the clipboard. |
| Name | Description |
|---|---|
| AfxCaptureDisplay | Captures the display and returns an handle to a bitmap. |
| AfxGetBitmapHeight | Retrieves the height of the specified bitmap. |
| AfxGetBitmapWidth | Retrieves the width of the specified bitmap. |
| Name | Description |
|---|---|
| AfxCreateDIBSection | Creates a DIB section. |
| AfxDibLoadImage | Loads a DIB in memory and returns a pointer to it. |
| AfxDibSaveImage | Saves a DIB to a file. |
| Name | Description |
|---|---|
| AfxHiMetricToPixelsX | Converts from HiMetric to Pixels (horizontal resolution). |
| AfxHiMetricToPixelsY | Converts from HiMetric to Pixels (vertical resolution). |
| AfxPixelsToHiMetricX | Converts from Pixels to HiMetric (horizontal resolution). |
| AfxPixelsToHiMetricY | Converts from Pixels to HiMetric (vertical resolution). |
| AfxPixelsToPointsX | Converts pixels to points size (1/72 of an inch) (horizontal resolution). |
| AfxPixelsToPointsY | Converts pixels to points size (1/72 of an inch) (vertical resolution). |
| AfxPixelsToTwipsX | Converts pixels to twips (horizontal resolution). |
| AfxPixelsToTwipsY | Converts pixels to twips (vertical resolution). |
| AfxPointSizeToDip | Converts point size to DIP (device independent pixel). |
| AfxPointsToPixelsX | Converts a point size (1/72 of an inch) to pixels (horizontal resolution). |
| AfxPointsToPixelsY | Converts a point size (1/72 of an inch) to pixels (vertical resolution). |
| AfxTwipsPerPixelX | Returns the width of a pixel in twips (horizontal resolution). |
| AfxTwipsPerPixelY | Returns the width of a pixel in twips (vertical resolution). |
| AfxTwipsToPixelsX | Converts twips to pixels (horizontal resolution). |
| AfxTwipsToPixelsY | Converts twips to pixels (vertical resolution). |
| Name | Description |
|---|---|
| AfxGetDefaultBrowserName | Retrieves the name of the default browser. |
| AfxGetDefaultBrowserPath | Retrieves the path of the default browser. |
| AfxGetDefaultMailClientName | Retrieves the name of the default client mail application. |
| AfxGetDefaultMailClientPath | Retrieves the path of the default mail client application. |
| AfxGetInternetExplorerVersion | Returns the Internet Explorer version installed. |
| AfxInternetAttemptConnect | Attempts to make a connection to the Internet. |
| AfxInternetCheckConnection | Checks if a connection to the Internet can be established. |
| AfxInternetCanonicalizeUrl | Canonicalizes a URL, which includes converting unsafe characters and spaces into escape sequences. |
| AfxInternetCombineUrl | Combines a base and relative URL into a single URL. The resultant URL is canonicalized. |
| AfxInternetGetConnectedState | Retrieves the connected state of the local system. |
| AfxInternetGetConnectionDescription | Retrieves the connection description. |
| AfxInternetGetConnectionName | Retrieves the connection name. |
| Name | Description |
|---|---|
| AfxAppsUseDarkMode | Returns TRUE if Windows applications are using dark mode, or FALSE otherwise. |
| AfxAvailablePageFile | Returns maximum amount of memory the current process can commit, in bytes. |
| AfxAvailablePhysicalMemory | Returns the amount of physical memory currently available, in bytes. |
| AfxAvailableVirtualMemory | Returns size of the user-mode portion of the virtual address space of the calling process, in bytes. |
| AfxComCtlVersion | Returns the version of CommCtl32.dll. |
| AfxGetPhysicallyInstalledSystemMemory | Retrieves the amount of RAM that is physically installed on the computer, in kilobytes. |
| AfxGetProductInfo | Retrieves the product type for the operating system on the local computer, and maps the type to the product types supported by the specified operating system. |
| AfxGetUserDomain | Retrieves the name of the user associated with the current thread. |
| AfxGetWindowsBuild | Returns the Windows build number. |
| AfxGetWindowsInstallDate | Returns the date in which Windows was installed, in Unix time. |
| AfxGetWindowsMajorVersion | Returns the Windows major version. |
| AfxGetWindowsMinorVersion | Returns the Windows minor version. |
| AfxGetWindowsPlatform | Returns the Windows platform. |
| AfxGetWindowsVersion | Returns the Windows version. |
| AfxGetWindowsVersionStr | Returns the full Windows version as a string. |
| AfxIsPlatformNT | Returns TRUE if the Windows Platform is NT; FALSE, otherwise. |
| AfxIsProcessElevated | Checks if the process is running with real administrative privileges. |
| AfxMemoryLoad | Returns the amount of actual physical memory, in bytes. |
| AfxPhysicallyInstalledSystemMemory | Retrieves the amount of RAM that is physically installed on the computer, in kilobytes. |
| AfxProcessorArchitecture | Returns the processor architecture of the operating system. |
| AfxProcessorsCount | Returns the number of processors. |
| AfxSystemUsesDarkMode | Returns TRUE if Windows is using dark mode, or FALSE otherwise. |
| AfxTotalPageFile | Returns the current committed memory limit for the system or the current process, whichever is smaller, in bytes. |
| AfxTotalPhysicalMemory | Returns the amount of actual physical memory, in bytes. |
| AfxTotalVirtualMemory | Returns size of the user-mode portion of the virtual address space of the calling process, in bytes. |
| AfxWindowsBitness | Returns the bitness of the operating system (32 or 64 bit). |
| AfxWindowsBuild | Returns the Windows build number. |
| AfxWindowsFeatureUpdate | Returns the Windows feature update versión, e.g. 22H2. |
| AfxWindowsInstallDate | Returns the date in which Windows was installed, in Unix time. |
| AfxWindowsPlatform | Returns the Windows platform. |
| AfxWindowsMajorVersion | Returns the Windows major version. |
| AfxWindowsMinorVersion | Returns the Windows minor version. |
| AfxWindowsVersion | Returns the Windows version. |
| AfxWindowsVersionStr | Returns the full Windows version as a string. |
| Name | Description |
|---|---|
| ACLineStatus | Retrieves the AC power status. |
| AfxBatteryChargeStatus | Retrieves the battery charge status. |
| AfxBatteryLifePercent | Retrieves the percentage of full battery charge remaining. |
| AfxBatteryLifeTime | Retrieves the number of seconds of battery life remaining. |
| AfxBatteryFullLifeTime | Retrieves the number of seconds of battery life when at full charge |
Returns command line parameters used to call the program. Unicode replacement for FreeBasic’s Command keyword. WCOmmand is an alias or AfxCommand.
FUNCTION AfxCommand (BYVAL nIndex AS LONG = -1) AS DWSTRING
#define WCommand AfxCommand
| Parameter | Description |
|---|---|
| nIndex | Zero-based index for a particular command-line argument. |
Returns the command-line arguments(s).
AfxCommand returns command-line arguments passed to the program upon execution.
If index is less than zero (< 0), a space-separated list of all command-line arguments is returned, otherwise, a single argument is returned. A value of zero (0) returns the name of the executable; and values of one (1) and greater return each command-line argument.
If index is greater than the number of arguments passed to the program, a null string (““) is returned.
Returns the number of command line arguments used to call the program. WCommandArgsc is an alias for AfxCommandLineCount.
FUNCTION AfxCommandLineCount (BYVAL nIndex AS LONG = -1) AS DWSTRING
#define WCommandArgsc AfxCommandLineCount
The number of command line arguments used to call the program.
Extracts resource data and returns it as a string.
FUNCTION AfxExtractResource (BYVAL hInstance AS HINSTANCE, _
BYREF wszResourceName AS WSTRING, BYVAL pResourceType AS LPWSTR = MAKEINTRESOURCEW(10)) AS STRING
| Parameter | Description |
|---|---|
| hInstance | A handle to the module whose portable executable file or an accompanying MUI file contains the resource. If this parameter is NULL, the function searches the module used to create the current process. |
| wszResourceName | Name of the resource. If the resource is an image that uses an integral identifier, wszResourceName should begin with a number symbol (#) followed by the identifier in an ASCII format, e.g., “#998”. Otherwise, use the text identifier name for the image. Only images embedded as raw data (type RCDATA) are valid. These must be in format .png, .jpg, .gif, .tiff. |
| pResourceType | Type of the resource, e.g. RT_RCDATA. For a list of predefined resource types see: Resource Types |
A string containing the resource data.
DIM strResData AS STRING = AfxExtractResource(NULL, "IDI_ARROW_RIGHT")
where IDI_ARROW_RIGHT is the identifier in the resource file for
IDI_ARROW_RIGHT RCDATA ".\Resources\arrow_right_64.png"
--or--
DIM strResData AS STRING = AfxExtractResource(NULL, "#111")
' where "#111" is the identifier in the resource file for
' 111 RCDATA ".\Resources\VEGA_PAZ_01.jpg"
-----
' // Write the resource data to a file
DIM hFile AS HANDLE = CreateFileW("PazVega.jpg", GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL)
IF hFile THEN
DIM dwBytesWritten AS DWORD
DIM bSuccess AS BOOLEAN = WriteFile(hFile, STRPTR(strResData), LEN(strResData), @dwBytesWritten, NULL)
CloseHandle(hFile)
print bSuccess
END IF
Extracts resource data and saves it to a file.
FUNCTION AfxExtractResourceToFile (BYVAL hInstance AS HINSTANCE, BYREF wszResourceName AS WSTRING, _
BYREF wszFileName AS WSTRING, BYVAL pResourceType AS LPWSTR = MAKEINTRESOURCEW(10)) AS STRING
| Parameter | Description |
|---|---|
| hInstance | A handle to the module whose portable executable file or an accompanying MUI file contains the resource. If this parameter is NULL, the function searches the module used to create the current process. |
| wszResourceName | Name of the resource. If the resource is an image that uses an integral identifier, wszResourceName should begin with a number symbol (#) followed by the identifier in an ASCII format, e.g., “#998”. Otherwise, use the text identifier name for the image. Only images embedded as raw data (type RCDATA) are valid. These must be in format .png, .jpg, .gif, .tiff. |
| wszFileName | Path of the file where to save the extracted resource. |
| pResourceType | Type of the resource, e.g. RT_RCDATA. For a list of predefined resource types see: Resource Types |
TRUE on success of FALSE on failure.
AfxExtractResourceToFile(NULL, "IDI_ARROW_RIGHT", "IDI_ARROW_RIGHT.png")
where IDI_ARROW_RIGHT is the identifier in the resource file for
IDI_ARROW_RIGHT RCDATA ".\Resources\arrow_right_64.png"
AfxExtractResourceToFile(NULL, "#111", "VEGA_PAZ_01.jpg")
where "#111" is the identifier in the resource file for
111 RCDATA ".\Resources\VEGA_PAZ_01.jpg"
Changes the current directory for the current process. Aliases: AfxSetCurDir, AfxSetCurrentDirectory.
FUNCTION AfxChDir (BYVAL pwszPathName AS LPCWSTR) AS LONG
FUNCTION AfxSetCurDir (BYVAL pwszPathName AS LPCWSTR) AS BOOLEAN
FUNCTION AfxSetCurrentDirectory (BYVAL pwszPathName AS LPCWSTR) AS BOOLEAN
| Parameter | Description |
|---|---|
| lpPathName | The path to the new current directory. This parameter may specify a relative path or a full path. In either case, the full path of the specified directory is calculated and stored as the current directory. |
If the function succeeds, the return value is 0.
If the function
fails, the return value is -1.
To get extended error information,
call GetLastError.
AfxMkDir is an unicode replacement for Free Basic’s MkDir.
If the function succeeds, the return value is TRUE.
If the
function fails, the return value is FALSE.
To get extended error
information, call GetLastError.
Copies an existing file to a new file. Alias: AfxFileCopy.
FUNCTION AfxCopyFile (BYVAL lpExistingFileName AS LPCWSTR, BYVAL lpNewFileName AS LPCWSTR, _
BYVAL bFailIfExists AS BOOLEAN = FALSE) AS BOOLEAN
FUNCTION AfxFileCopy (BYVAL lpExistingFileName AS LPCWSTR, BYVAL lpNewFileName AS LPCWSTR, _
BYVAL bFailIfExists AS BOOLEAN = FALSE) AS BOOLEAN
| Parameter | Description |
|---|---|
| lpExistingFileName | The name of an existing file. To extend the limit of MAX_PATH characters to 32,767 wide characters prepend “\\?\” to the path. If lpExistingFileName does not exist, CopyFile fails, and GetLastError returns ERROR_FILE_NOT_FOUND. |
| lpNewFileName | The name of the new file. To extend the limit of MAX_PATH characters to 32,767 wide characters prepend “\\?\” to the path. |
| bFailIfExists | If this parameter is TRUE and the new file specified by lpNewFileName already exists, the function fails. If this parameter is FALSE and the new file already exists, the function overwrites the existing file and succeeds. |
If the function succeeds, the return value is TRUE.
If the
function fails, the return value is FALSE. To get extended error
information, call GetLastError.
AfxFileCopy is an unicode replacement for Free Basic’s FileCopy and returns 0 on success, or 1 if an error occurred.
Creates a new directory. Aliases: AfxMakeDir, AfxCreateDirectory.
FUNCTION AfxMkDir (BYVAL lpPathName AS LPCWSTR) AS LONG
FUNCTION AfxCreateDirectory (BYVAL lpPathName AS LPCWSTR) AS BOOLEAN
FUNCTION AfxMakeDir (BYVAL lpPathName AS LPCWSTR) AS BOOLEAN
| Parameter | Description |
|---|---|
| lpPathName | The path of the directory to be created. To extend the limit to 32,767 wide characters, prepend “\\?\” to the path. |
If the function succeeds, the return value is 0.
If the function
fails, the return value is -1.
To get extended error information,
call GetLastError.
AfxMkDir is an unicode replacement for Free Basic’s MkDir.
If the function succeeds, the return value is TRUE.
If the
function fails, the return value is FALSE.
To get extended error
information, call GetLastError.
Possible errors include the following.
| Error | Description |
|---|---|
| ERROR_ALREADY_EXISTS | The specified directory already exists. |
| ERROR_PATH_NOT_FOUND | One or more intermediate directories do not exist; this function will only create the final directory in the path. |
Deletes the specified file. Alias: AfxKill.
FUNCTION AfxDeleteFile (BYVAL pwszFileSpec AS WSTRING PTR) AS BOOLEAN
FUNCTION AfxKill (BYVAL pwszFileSpec AS WSTRING PTR) AS BOOLEAN
| Parameter | Description |
|---|---|
| pwszFileSpec | The full path and name of the file to delete. To extend the limit to 32,767 wide characters, prepend “\\?\” to the path. |
If the function succeeds, the return value is TRUE.
If the
function fails, the return value is FALSE.
To get extended error
information, call GetLastError.
If an application attempts to delete a file that does not exist, this function fails with ERROR_FILE_NOT_FOUND. If the file is a read-only file, the function fails with ERROR_ACCESS_DENIED.
AfxKill is an unicode replacement for Free Basic’s Kill and returns 0 on success, or -1 on failure.
Returns the file’s last modified date and time as Date Serial. Unicode replacement for Free Basic’s FileDateTime.
FUNCTION AfxFileDateTime (BYREF wszFileName AS WSTRING) AS DOUBLE
The date and time as a Date Serial. If it fails, it returns 0.
#include "windows.bi"
#include "vbcompat.bi"
#include "Afx/AfxWin.bi"
DIM wszFileName AS WSTRING * MAX_PATH = ExePath & "\c2.bas"
DIM dt AS DOUBLE = AfxFileDateTime(wszFileName)
PRINT Format(dt, "yyyy-mm-dd hh:mm AM/PM")
Retrieves the current directory for the current process. Aliases: AfxGetCurDir, AfxGetCurrentDirectory- Unicode replacement for Free Basic’s CurDir.
FUNCTION AfxCurDir () AS DWSTRING
FUNCTION AfxGetCurDir () AS DWSTRING
FUNCTION AfxGetCurrentDirectory () AS DWSTRING
The name of the current directory for the current process.
Moves an existing file or a directory, including its children. Aliases: AfxRenameFile, AfxMoveFile. AfxName is an unicode replacement for Free Basic’s Name.
FUNCTION AfxName (BYVAL lpExistingFileName AS LPCWSTR, BYVAL lpNewFileName AS LPCWSTR) AS LONG
FUNCTION AfxRenameFile (BYVAL lpExistingFileName AS LPCWSTR, BYVAL lpNewFileName AS LPCWSTR) AS BOOLEAN
FUNCTION AfxMoveFile (BYVAL lpExistingFileName AS LPCWSTR, BYVAL lpNewFileName AS LPCWSTR) AS BOOLEAN
| Parameter | Description |
|---|---|
| lpExistingFileName | The name of an existing file. To extend the limit to 32,767 wide characters, prepend “\\?\” to the path. If lpExistingFileName does not exist, AfxRenameFile fails, and GetLastError returns ERROR_FILE_NOT_FOUND. |
| lpNewFileName | The name of the new file. To extend the limit to 32,767 wide characters, prepend “\\?\” to the path. |
If the function succeeds, the return value is 0.
If the function
fails, the return value is -1.
To get extended error information,
call GetLastError.
AfxName is an unicode replacement for Free Basic’s Name.
If the function succeeds, the return value is TRUE.
If the
function fails, the return value is FALSE.
To get extended error
information, call GetLastError.
Deletes an existing empty directory. Aliases: AfxRemoveDirectory. AfxRmDir is an unicode replacement for Free Basic’s RmDir.
FUNCTION AfxRmDir (BYVAL lpPathName AS LPCWSTR) AS LONG
FUNCTION AfxRemoveDir (BYVAL lpPathName AS LPCWSTR) AS BOOLEAN
FUNCTION AfxRemoveDirectory (BYVAL lpPathName AS LPCWSTR) AS BOOLEAN
| Parameter | Description |
|---|---|
| lpPathName | The path of the directory to be removed. This path must specify an empty directory, and the calling process must have delete access to the directory. To extend the limit to 32,767 wide characters, prepend “\\?\” to the path. |
If the function succeeds, the return value is 0.
If the function
fails, the return value is -1.
To get extended error information,
call GetLastError.
AfxRmDir is an unicode replacement for Free Basic’s RmDir.
If the function succeeds, the return value is TRUE.
If the
function fails, the return value is FALSE.
To get extended error
information, call GetLastError.
These functions mark a directory for deletion on close. Therefore, the directory is not removed until the last handle to the directory is closed. To recursively delete the files in a directory, use the SHFileOperation function.
Searches a directory for a file or subdirectory with a name that matches a specific name (or partial name if wildcards are used).
FUNCTION AfxFileExists (BYVAL pwszFileSpec AS WSTRING PTR) AS BOOLEAN
| Parameter | Description |
|---|---|
| pwszFileSpec | The directory or path, and the file name, which can include wildcard characters, for example, an asterisk (*) or a question mark (?). This parameter should not be NULL, an invalid string (for example, an empty string or a string that is missing the terminating null character), or end in a trailing backslash (\). If the string ends with a wildcard, period (.), or directory name, the user must have access permissions to the root and all subdirectories on the path. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Boolean. TRUE if the specified file exist or FALSE otherwise.
Prepending the string “\\?\” does not allow access to the root directory.
On network shares, you can use an pwszFileSpec in the form of the following: “\\server\*”. However, you cannot use an pwszFileSpec that points to the share itself; for example, “\\server” is not valid.
To examine a directory that is not a root directory, use the path to that directory, without a trailing backslash. For example, an argument of “C:” returns information about the directory “C:”, not about a directory or file in “C:”. To examine the files and directories in “C:”, use an pwszFileSpec of “C:*”.
Be aware that some other thread or process could create or delete a file with this name between the time you query for the result and the time you act on the information. If this is a potential concern for your application, one possible solution is to use the CreateFile function with CREATE_NEW (which fails if the file exists) or OPEN_EXISTING (which fails if the file does not exist).
Searches a directory for a file or subdirectory with a name that matches a specific name (or partial name if wildcards are used).
FUNCTION AfxFolderExists (BYVAL pwszFileSpec AS WSTRING PTR) AS BOOLEAN
| Parameter | Description |
|---|---|
| pwszFileSpec | The directory or path, and the file name, which can include wildcard characters, for example, an asterisk (*) or a question mark (?). This parameter should not be NULL, an invalid string (for example, an empty string or a string that is missing the terminating null character), or end in a trailing backslash (\). If the string ends with a wildcard, period (.), or directory name, the user must have access permissions to the root and all subdirectories on the path. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Boolean. TRUE if the specified file exist or FALSE otherwise.
Prepending the string “\\?\” does not allow access to the root directory.
On network shares, you can use an pwszFileSpec in the form of the following: “\\server\*”. However, you cannot use an pwszFileSpec that points to the share itself; for example, “\\server” is not valid.
To examine a directory that is not a root directory, use the path to that directory, without a trailing backslash. For example, an argument of “C:” returns information about the directory “C:”, not about a directory or file in “C:”. To examine the files and directories in “C:”, use an pwszFileSpec of “C:\*”.
Be aware that some other thread or process could create or delete a file with this name between the time you query for the result and the time you act on the information. If this is a potential concern for your application, one possible solution is to use the CreateFile function with CREATE_NEW (which fails if the file exists) or OPEN_EXISTING (which fails if the file does not exist).
Returns the size in bytes of the specified file. Alias: AfxFileLen.
FUNCTION AfxGetFileSize (BYREF wszFileSpec AS WSTRING) AS ULONGLONG
FUNCTION AfxFileLen (BYREF wszFileSpec AS WSTRING) AS ULONGLONG
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
The size in bytes of the file on success, or 0 on failure.
Returns the path of the program which is currently executing.
FUNCTION AfxExePath () AS DWSTRING
FUNCTION AfxGetExePath () AS DWSTRING
Unicode replacement for Free Basic’s ExePath function. The path name has not a trailing backslash, except if it is a drive, e.g. “C:".
AfxGetExePath.
Returns the path of the program which is currently executing.
FUNCTION AfxGetExePathName () AS DWSTRING
The path name has a trailing backslash.
AfxExePathName
Determines whether a disk drive is a removable, fixed, CD-ROM, RAM disk, or network drive.
FUNCTION AfxGetDriveType (BYVAL lpRootPathName AS LPCWSTR) as UINT
| Parameter | Description |
|---|---|
| lpRootPathName | The root directory for the drive. A trailing backslash is required. If this parameter is NULL, the function uses the root of the current directory. |
DRIVE_UNKNOWN (0), DRIVE_NO_ROOT_DIR (1), DRIVE_REMOVABLE (2), DRIVE_FIXED(3), DRIVE_REMOTE (4), DRIVE_CDROM (5), DRIVE_RAMDISK (6).
Parses a path/filename and returns the extension portion of the path/file name.
FUNCTION AfxGetExeFileExt () AS DWSTRING
The extension portion of the file name. That is the last period (.) in the string plus the text to the right of it.
AfxExeFileExt
Returns the file name of the program which is currently executing.
FUNCTION AfxGetExeFileName () AS DWSTRING
** AfxExeFilename**
Returns the file name and extension of the program which is currently executing.
FUNCTION AfxGetExeFileNameX () AS DWSTRING
** AfxExeFilenameX**
Returns the complete drive, path, file name, and extension of the program which is currently executing.
FUNCTION AfxGetExeFullPath () AS DWSTRING
AfxExeFullPath
Parses a path/filename and returns the extension portion of the path/file name. That is the last period (.) in the string plus the text to the right of it.
FUNCTION AfxGetFileExt (BYREF wszPath AS WSTRING) AS DWSTRING
| Parameter | Description |
|---|---|
| wszPath | The path/filename string. |
AfxFileExt
Returns the time the file was created, in FILETIME format.
FUNCTION AfxGetFileCreationTime (BYREF wszFileSpec AS WSTRING, BYVAL bUTC AS BOOLEAN = TRUE) AS FILETIME
| Parameter | Description |
|---|---|
| wszFileSpec | The directory or path, and the file name, which can include wildcard characters, for example, an asterisk (*) or a question mark (?). This parameter should not be NULL, an invalid string (for example, an empty string or a string that is missing the terminating null character), or end in a trailing backslash (\). If the string ends with a wildcard, period (.), or directory name, the user must have access permissions to the root and all subdirectories on the path. To extend the limit from MAX_PATH to 32,767 wide characters, prepend “\\?\” to the path. |
| bUTC | Optional. Pass FALSE if you want to get the time in local time (the NTFS file system stores time values in UTC format, so they are not affected by changes in time zone or daylight saving time). FileTimeToLocalFileTime uses the current settings for the time zone and daylight saving time. Therefore, if it is daylight saving time, it takes daylight saving time into account, even if the file time you are converting is in standard time. |
Returns the time the file was accessed, in FILETIME format.
FUNCTION AfxGetFileLastAccessTime (BYREF wszFileSpec AS WSTRING, BYVAL bUTC AS BOOLEAN = TRUE) AS FILETIME
| Parameter | Description |
|---|---|
| wszFileSpec | The directory or path, and the file name, which can include wildcard characters, for example, an asterisk (*) or a question mark (?). This parameter should not be NULL, an invalid string (for example, an empty string or a string that is missing the terminating null character), or end in a trailing backslash (\). If the string ends with a wildcard, period (.), or directory name, the user must have access permissions to the root and all subdirectories on the path. To extend the limit from MAX_PATH to 32,767 wide characters, prepend “\\?\” to the path. |
| bUTC | Optional. Pass FALSE if you want to get the time in local time (the NTFS file system stores time values in UTC format, so they are not affected by changes in time zone or daylight saving time). FileTimeToLocalFileTime uses the current settings for the time zone and daylight saving time. Therefore, if it is daylight saving time, it takes daylight saving time into account, even if the file time you are converting is in standard time. |
Returns the time the file was last written to, truncated, or overwritten, in FILETIME format.
FUNCTION AfxGetFileLastWriteTime (BYREF wszFileSpec AS WSTRING, BYVAL bUTC AS BOOLEAN = TRUE) AS FILETIME
| Parameter | Description |
|---|---|
| wszFileSpec | The directory or path, and the file name, which can include wildcard characters, for example, an asterisk (*) or a question mark (?). This parameter should not be NULL, an invalid string (for example, an empty string or a string that is missing the terminating null character), or end in a trailing backslash (\). If the string ends with a wildcard, period (.), or directory name, the user must have access permissions to the root and all subdirectories on the path. To extend the limit from MAX_PATH to 32,767 wide characters, prepend “\\?\” to the path. |
| bUTC | Optional. Pass FALSE if you want to get the time in local time (the NTFS file system stores time values in UTC format, so they are not affected by changes in time zone or daylight saving time). FileTimeToLocalFileTime uses the current settings for the time zone and daylight saving time. Therefore, if it is daylight saving time, it takes daylight saving time into account, even if the file time you are converting is in standard time. |
Parses a path/filename and returns the file name portion. That is the text to the right of the last backslash () or colon (:), ending just before the last period (.).
FUNCTION AfxGetFileName (BYREF wszPath AS WSTRING) AS DWSTRING
| Parameter | Description |
|---|---|
| wszPath | The path/filename string. |
AfxFileName
Parses a path/filename and returns the file name and extension portion. That is the text to the right of the last backslash (\) or colon (:).
FUNCTION AfxGetFileNameX (BYREF wszPath AS WSTRING) AS DWSTRING
| Parameter | Description |
|---|---|
| wszPath | The path/filename string. |
AfxFileNameX
Retrieves the version of the specified file multiplied by 100, e.g. 601 for version 6.01.
FUNCTION AfxGetFileVersion (BYVAL pwszFileName AS WSTRING PTR) AS DWORD
| Parameter | Description |
|---|---|
| wszPath | The path/filename string. |
Returns a string containing the name of the folder for a specified path, i.e. the path minus the file name.
FUNCTION AfxGetFolderName (BYREF wszPath AS WSTRING) AS DWSTRING
| Parameter | Description |
|---|---|
| wszPath | The path/filename string. |
AfxGetFolderName
Retrieves the path of an special folder.
FUNCTION AfxGetKnowFolderPath (BYVAL rfid AS CONST KNOWNFOLDERID CONST PTR, _
BYVAL dwFlags AS DWORD = 0, BYVAL hToken AS HANDLE = NULL) AS DWSTRING
| Parameter | Description |
|---|---|
| rfid | A reference to the KNOWNFOLDERID that identifies the folder. The folders associated with the known folder IDs might not exist on a particular system. |
| dwFlags | Flags that specify special retrieval options. This value can be 0; otherwise, it is one or more of the KNOWN_FOLDER_FLAG values. |
| hToken | An access token used to represent a particular user. This parameter
is usually set to NULL, in which case the function tries to access the
current user’s instance of the folder. However, you may need to assign a
value to hToken for those folders that can have multiple users
but are treated as belonging to a single user. The most commonly used
folder of this type is Documents. The calling application is responsible
for correct impersonation when hToken is non-null. It must have
appropriate security privileges for the particular user, including
TOKEN_QUERY and TOKEN_IMPERSONATE, and the user’s registry hive must be
currently mounted. See Access
Control for further discussion of access control
issues. Assigning the hToken parameter a value of -1 indicates the Default User. This allows clients of SHGetKnownFolderIDList to find folder locations (such as the Desktop folder) for the Default User. The Default User user profile is duplicated when any new user account is created, and includes special folders such as Documents and Desktop. Any items added to the Default User folder also appear in any new user account. Note that access to the Default User folders requires administrator privileges. |
The path of the requested folder on success, or an empty string on failure.
Requires Windows Vista/Windows 7 or superior.
For a list of KNOWNFOLDERID constants see: KNOWNFOLDERID
AfxGetKnowFolderPath(@FOLDERID_CommonPrograms)
Retrieves the short path form of the specified path.
FUNCTION AfxGetLongPathName (BYREF wszPath AS WSTRING) AS DWSTRING
| Parameter | Description |
|---|---|
| wszPath | The path/filename string. To extend the limit of MAX_PATH wode characters to 32,767 wide characters, prepend “\\?\” to the path. |
AfxLongPathName
Retrieves the path of the executable file given its process identifier.
FUNCTION AfxGetPathFromProcessId (BYVAL dwProcessId AS DWORD) AS DWSTRING
| Parameter | Description |
|---|---|
| dwProcessId | The process identifier. |
AfxPathFromProcessId
Parses a path/filename and returns the path portion. That is the text up to and including the last backslash () or colon (:).
FUNCTION AfxGetPathName (BYREF wszPath AS WSTRING) AS DWSTRING
| Parameter | Description |
|---|---|
| wszPath | The path/filename string. |
AfxPathName
Retrieves the short path form of the specified path.
FUNCTION AfxGetShortPathName (BYREF wszPath AS WSTRING) AS DWSTRING
| Parameter | Description |
|---|---|
| wszPath | The path/filename string. To extend the limit of MAX_PATH wode characters to 32,767 wide characters, prepend “\\?\” to the path. |
AfxShortPathName
Retrieves the path of a special folder.
FUNCTION AfxGetSpecialFolderLocation (BYVAL nFolder AS LONG) AS DWSTRING
| Parameter | Description |
|---|---|
| nFolder | A CSIDL value that identifies the folder of interest. |
For a list of CSIDL values see: CSIDL
Retrieves the fully qualified path for the file that contains the specified module.
FUNCTION AfxGetSystemDllPath (BYREF wszDllName AS WSTRING) AS DWSTRING
| Parameter | Description |
|---|---|
| wszDllName | The name of the system DLL to find. |
To locate the file for a module that was loaded by another process, use the GetModuleFileNameEx function.
AfxSystemDllPath
Returns the system drive name, e.g. “C:”.
FUNCTION AfxSystemDrive () AS DWSTRING
AfxGetSystemDrive
Retrieves the path of the system directory.
FUNCTION AfxSystemDirectory () AS DWSTRING
AfxGetSystemDirectory
Retrieves the path of the Windows directory. This path does not end with a backslash unless the Windows directory is the root directory. For example, if the Windows directory is named Windows on drive C, the path of the Windows directory retrieved by this function is C:. If the system was installed in the root directory of drive C, the path retrieved is C:\.
FUNCTION AfxGetWinDir () AS DWSTRING
AfxWindir, “AfxWindowsDirectory
Retrieves the path of the directory designated for temporary files.
FUNCTION AfxGetTempPath () AS DWSTRING
AfxTempPath
Retrieves the path of the system directory used by WOW64. This directory is not present on 32-bit Windows.
FUNCTION AfxGetSystemWow64Directory () AS DWSTRING
AfxSystemWow64Directory
Returns True if the specified file or directory is compressed; False if it is not.
FUNCTION AfxIsCompressedFile (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Returns True if the specified file or directory is encrypted; False if it is not.
FUNCTION AfxIsEncryptedFile (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Returns True if the specified path is a folder; False if it is not.
FUNCTION AfxIsFolder (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Returns True if the specified path is a hidden file or directory; False if it is not.
FUNCTION AfxIsHiddenFile (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Returns True if the specified path is a normal file (a file that does not have other attributes set); False if it is not.
FUNCTION AfxIsNormalFile (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Returns TRUE if the specified file or directory is not to be indexed by the content indexing service; FALSE, otherwise.
FUNCTION AfxIsNotContentIndexedFile (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Returns TRUE if the specified file file is not available immediately; FALSE, otherwise.
FUNCTION AfxIsOfflineFile (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Returns True if the specified path is a read only file; False if it is not.
FUNCTION AfxIsReadOnlyFile (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Returns TRUE if the specified path is a file or directory that has an associated reparse point, or a file that is a symbolic link.; FALSE, otherwise.
FUNCTION AfxIsReparsePointFile (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Returns TRUE if the specified path is a sparse file; FALSE, otherwise.
FUNCTION AfxIsSparseFile (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Returns True if the specified path is a system file; False if it is not.
FUNCTION AfxIsSystemFile (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Returns True if the specified path is a temporary file; False if it is not.
FUNCTION AfxIsTemporaryFile (BYREF wszFileSpec AS WSTRING) AS BOOLEAN
| Parameter | Description |
|---|---|
| wszFileSpec | The path to a file. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
Scans a text file ans returns the number of occurrences of the specified delimiter.
FUNCTION AfxFileScanA (BYREF wszFileName AS WSTRING, BYREF Delimiter AS ZSTRING = CHR(13, 10)) AS DWORD
FUNCTION AfxFileScanW (BYREF wszFileName AS WSTRING, BYREF Delimiter AS WSTRING = CHR(13, 10)) AS DWORD
| Parameter | Description |
|---|---|
| wszFileName | Path of the file to scan. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
| Delimiter | Optional. Delimiter to find. Default value is CHR(13, 10), which returns the number of lines. You can use CHR(10) for Linux files, “,” for comma delimited cvs files, CHR(9) for spreadshets in tab delimited format, etc. |
Use AfxFileScanA for ansi text files and AfxFileScanW for unicode text files.
Reads all the lines of the specified file into a safe array.
FUNCTION AfxFileReadAllLinesA (BYREF wszFileName AS WSTRING, BYREF Delimiter AS ZSTRING = CHR(13, 10)) AS DSafeArray
FUNCTION AfxFileReadAllLinesW (BYREF wszFileName AS WSTRING, BYREF Delimiter AS WSTRING = CHR(13, 10)) AS DSafeArray
| Parameter | Description |
|---|---|
| wszFileName | Path of the file to scan. To extend the limit of MAX_PATH wide characters to 32,767 wide characters, prepend “\\?\” to the path. |
| Delimiter | Optional. Delimiter to find. Default value is CHR(13, 10), which returns the number of lines. You can use CHR(10) for Linux files, “,” for comma delimited cvs files, CHR(9) for spreadshets in tab delimited format, etc. |
Use AfxFileReadAllLinesA for ansi text files and AfxFileReadAllLinesW for unicode text files.
Because it returns a safe array, this function is located in the DSafeArray.inc include file.
Saves an icon to a file.
FUNCTION AfxSaveIconToFile (BYVAL hIcon AS HICON, BYREF fileName AS WSTRING) AS HRESULT
| Parameter | Description |
|---|---|
| hIcon | The icon handle. |
| fileName | The name of the file to save. |
Returns S_OK on success or and HRESULT code on failure.
DIM hIcon as HICON = LoadIcon(NULL, IDI_INFORMATION)
DIM hr AS HRESULT = AfxSaveIconToFile(hIcon, "test.ico")
DIM hIcon AS HICON = cast(HICON, LoadImage(NULL, ExePath & "\" & "MyIco.ico", IMAGE_ICON, 32, 32, LR_LOADFROMFILE))
DIM hr AS HRESULT = AfxSaveIconToFile(hIcon, "test2.ico")
Saves the contents of a string buffer in a temporary file.
FUNCTION AfxSaveTempFile (BYVAL pwszBuffer AS WSTRING PTR, BYREF wszExtension AS WSTRING) AS DWSTRING
| Parameter | Description |
|---|---|
| pwszBuffer | The string buffer to save. |
| wszExtension | Optional. The extension of the file name without a colon (e.g. “bas”). If an empty string is passed, the function will use “tmp” as the extension. |
Temporary files whose names have been created by this function are not automatically deleted. To delete these files call AfxDeleteFile.
Adds a new extended style to the specified window.
FUNCTION AfxAddWindowExStyle (BYVAL hwnd AS HWND, BYVAL dwExStyle AS DWORD) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| dwExStyle | Extended style to add. |
The previous window extended styles.
AfxAddWindowExStyle(hwnd, WS_EX_COMPOSITED)
If the window has a class style of CS_CLASSDC or CS_OWNDC, do not set the extended window styles WS_EX_COMPOSITED or WS_EX_LAYERED.
Adds a new style to the specified window.
FUNCTION AfxAddWindowStyle (BYVAL hwnd AS HWND, BYVAL dwStyle AS DWORD) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| dwStyle | Style to add. |
The previous window styles.
AfxAddWindowStyle(hwnd, WS_HSCROLL)
Retrieves the extended window styles.
FUNCTION AfxGetWindowExStyle (BYVAL hwnd AS HWND) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
Retrieves the window styles.
FUNCTION AfxGetWindowStyle (BYVAL hwnd AS HWND) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
Removes an extended style from the specified window.
FUNCTION AfxRemoveWindowExStyle (BYVAL hwnd AS HWND, BYVAL dwExStyle AS DWORD) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| dwExStyle | The extended style to remove. |
The previous extended window styles.
Removes a style from the specified window.
FUNCTION AfxRemoveWindowStyle (BYVAL hwnd AS HWND, BYVAL dwStyle AS DWORD) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| dwStyle | The style to remove. |
The previous window styles.
Sets the extended style(s) of the specified window.
FUNCTION AfxSetWindowExStyle (BYVAL hwnd AS HWND, BYVAL dwExStyle AS DWORD) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| dwExStyle | The extended style(s) to set. |
The previous extended window styles.
Sets the style(s) of the specified window.
FUNCTION AfxSetWindowStyle (BYVAL hwnd AS HWND, BYVAL dwStyle AS DWORD) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| dwStyle | The style(s) to set. |
The previous window styles.
If you use dual (or even triple/quad) displays then you have undoubtedly encountered the following situation: You change the physical order of your displays, or otherwise reconfigure the logical ordering using your display software. This sometimes has the side-effect of changing your desktop coordinates from zero-based to negative starting coordinates (i.e. the top-left coordinate of your desktop changes from 0,0 to -1024,-768).
This effects many Windows programs which restore their last on-screen position whenever they are started. Should the user reorder their display configuration this can sometimes result in a Windows program subsequently starting in an off-screen position (i.e. at a location that used to be visible) - and is now effectively invisible, preventing the user from closing it down or otherwise moving it back on-screen.
The AfxForceVisibleDisplay function can be called at program start-time right after the main window has been created and positioned ‘on-screen’. Should the window be positioned in an off-screen position, it is forced back onto the nearest display to its last position. The user will be unaware this is happening and won’t even realize to thank you for keeping their user-interface visible, even though they changed their display settings.
Source: Catch-22 web site.
SUB AfxForceVisibleDisplay (BYVAL hwnd AS HWND)
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
Returns the color resolution, in bits per pixel, of the display device.
FUNCTION AfxGetDisplayBitsPerPixel () AS DWORD
AfxScreenColors, AfxGetScreenColors
Returns the frequency, in hertz (cycles per second), of the display device in a particular mode. This value is also known as the display device’s vertical refresh rate.
FUNCTION AfxGetDisplayBitsPerPixel () AS DWORD
AfxGetScreenRefreshDate, AfxScreenRefreshDate
Returns the height, in pixels, of the current display device on the computer on which the calling thread is running.
FUNCTION AfxGetDisplayPixelsHeight () AS DWORD
Returns the width, in pixels, of the current display device on the computer on which the calling thread is running.
FUNCTION AfxGetDisplayPixelsWidth () AS DWORD
Contrarily to GetSystemMetrics or GetDeviceCaps, it returns the real width even when it is called from an application that is not DPI aware, e.g. an application running virtualized in a monitor 1920 pixels width and a DPI of 192, will return 960 pixels if it calls GetSystemMetrics or GetDeviceCaps, but will return 1920 pixels calling AfxGetDisplayPixelsWidth.
Retrieves the height of the screen, in pixels. This function is virtualized for DPI.
FUNCTION AfxGetScreenHeight () AS LONG
AfxGetScreenHeight
Retrieves the width of the screen, in pixels. This function is virtualized for DPI.
FUNCTION AfxScreenWidth () AS LONG
AfxGetScreenWidth
Retrieves the coordinates of the work area on the primary display monitor expressed in virtual screen coordinates. The work area is the portion of the screen not obscured by the system taskbar or by application desktop toolbars. To get the work area of a monitor other than the primary display monitor, call the GetMonitorInfo function.
FUNCTION AfxGetWorkArea () AS RECT
AfxWorkArea
Processes pending Windows messages. Call this procedure if you are performing a tight FOR/NEXT or DO/LOOP and need to allow your application to be responsive to user input.
SUB AfxDoEvents (BYVAL hWin AS HWND = NULL)
| Parameter | Description |
|---|---|
| hWin | Optional. Handle of the window or dialog. If NULL, the window handle to the active window attached to the calling thread’s message queue is used. |
Sends a WM_SIZE message to the specified window.
FUNCTION AfxForwardSizeMessage (BYVAL hwnd AS HWND, BYVAL nResizeType AS DWORD, _
BYVAL nWidth AS LONG, BYVAL nHeight AS LONG) AS LRESULT
| Parameter | Description |
|---|---|
| hwnd | A handle to a window. |
| nResizeType | Type of resizing requested. |
| nWidth | The new width of the client area. |
| nHeight | The new height of the client ara. |
| Resizing type | Description |
|---|---|
| SIZE_MAXHIDE | Message is sent to all pop-up windows when some other window is maximized. |
| SIZE_MAXIMIZED | Maximize the window. |
| SIZE_MAXSHOW | Message is sent to all pop-up windows when some other window has been restored to its former size. |
| SIZE_MINIMIZED | Minimize the window. |
| SIZE_RESTORED | The window has been resized, but neither the SIZE_MINIMIZED nor SIZE_MAXIMIZED value applies. |
If an application processes this message, it should return zero.
Processes pending Windows messages. Call this procedure if you are performing a tight FOR/NEXT or DO/LOOP and need to allow your application to be responsive to user input.
SUB AfxPumpMessages
Returns the handle of the control with the specified identifier. The reference handle can be the handle of the form or the handle of any other control on the form.
FUNCTION AfxGetControlHandle (BYVAL hwnd AS HWND, BYVAL wCtrlID AS WORD) AS HWND
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| wCtrlID | Control identifier. |
Returns the handle of the control or NULL.
Finds the handle of the top-level window or MDI child window that is the ancestor of the specified window handle. The reference handle is the handle of any control on the form.
FUNCTION AfxGetFormHandle (BYVAL hwnd AS HWND) AS HWND
| Parameter | Description |
|---|---|
| hwnd | A handle to the control. |
Handle of the ancestor window.
Retrieves a window handle given it’s process identifier.
FUNCTION AfxGetHwndFromPID (BYVAL PID AS DWORD) AS HWND
| Parameter | Description |
|---|---|
| PID | The process identifier. |
The window handle or NULL.
Retrieves the path of the executable file that created the specified window.
FUNCTION AfxGetPathFromWindowHandle (BYVAL hwnd AS HWND) AS DWSTRING
| Parameter | Description |
|---|---|
| hwnd | The window handle. |
The path of the executable file.
AfxPathFromWindowHandle
Displays a dialog box that enables the user to select a folder.
FUNCTION AfxBrowseForFolder (BYVAL hwnd AS HWND, BYVAL pwszTitle AS WSTRING PTR = NULL, _
BYVAL pwszStartFolder AS WSTRING PTR = NULL, BYVAL nFlags AS LONG = 0) AS DWSTRING
| Parameter | Description |
|---|---|
| hwnd | The handle to the parent window of the dialog box. This value can be zero. |
| pwszTitle | Optional. A string value that represents the title displayed inside the Browse dialog box. |
| pwszStartFolder | Optional. The initial folder that the dialog will show. |
| nFlags | Optional. A LONG value that contains the options for the method. This can be zero or a combination of the values listed under the ulFlags member of the BROWSEINFO structure. |
| Flag | Description |
|---|---|
| BIF_RETURNONLYFSDIRS | Only return file system directories. If the user selects folders that are not part of the file system, the OK button is grayed. |
| BIF_DONTGOBELOWDOMAIN | Do not include network folders below the domain level in the dialog box’s tree view control. |
| BIF_STATUSTEXT | Include a status area in the dialog box. The callback function can set the status text by sending messages to the dialog box. This flag is not supported when BIF_NEWDIALOGSTYLE is specified. |
| BIF_RETURNFSANCESTORS | Only return file system ancestors. An ancestor is a subfolder that is beneath the root folder in the namespace hierarchy. If the user selects an ancestor of the root folder that is not part of the file system, the OK button is grayed. |
| BIF_EDITBOX | Version 4.71. Include an edit control in the browse dialog box that allows the user to type the name of an item. |
| BIF_NEWDIALOGSTYLE | Version 5.0. Use the new user interface. Setting this flag provides the user with a larger dialog box that can be resized. The dialog box has several new capabilities, including: drag-and-drop capability within the dialog box, reordering, shortcut menus, new folders, delete, and other shortcut menu commands. |
| BIF_USENEWUI | Version 5.0. Use the new user interface, including an edit box. This flag is equivalent to BIF_EDITBOX OR BIF_NEWDIALOGSTYLE. |
| BIF_UAHINT | Version 6.0. When combined with BIF_NEWDIALOGSTYLE, adds a usage hint to the dialog box, in place of the edit box. BIF_EDITBOX overrides this flag. |
| BIF_NONEWFOLDERBUTTON | Version 6.0. Do not include the New Folder button in the browse dialog box. |
| BIF_NOTRANSLATETARGETS | Version 6.0. When the selected item is a shortcut, return the PIDL of the shortcut itself rather than its target. |
| BIF_BROWSEFORCOMPUTER | Only return computers. If the user selects anything other than a computer, the OK button is grayed. |
| BIF_BROWSEFORPRINTER | Only allow the selection of printers. If the user selects anything other than a printer, the OK button is grayed. In Windows XP and later systems, the best practice is to use a Windows XP-style dialog, setting the root of the dialog to the Printers and Faxes folder (CSIDL_PRINTERS). |
| BIF_BROWSEINCLUDEFILES | Version 4.71. The browse dialog box displays files as well as folders. |
| BIF_SHAREABLE | Version 5.0. The browse dialog box can display shareable resources on remote systems. This is intended for applications that want to expose remote shares on a local system. The BIF_NEWDIALOGSTYLE flag must also be set. |
| BIF_BROWSEFILEJUNCTIONS | Windows 7 and later. Allow folder junctions such as a library or a compressed file with a .zip file name extension to be browsed. |
If COM is initialized through CoInitializeEx with the COINIT_MULTITHREADED flag set, AfxShellBrowserForFolder fails if BIF_NEWDIALOGSTYLE or BIF_USENEWUI are passed.
The path of the selected folder.
If you don’t pass any flags, the function will use BIF_RETURNONLYFSDIRS OR BIF_DONTGOBELOWDOMAIN OR BIF_USENEWUI OR BIF_RETURNFSANCESTORS.
DIM dws AS DWSTRING = AfxBrowseForFolder(hwnd, "C:")
Displays the Windows choose color dialog.
FUNCTION AfxChooseColorDialog (BYVAL hwnd AS HWND, BYVAL rgbDefaultColor AS COLORREF = 0, _
BYVAL lpCustColors AS COLORREF PTR = NULL) AS LONG
| Parameter | Description |
|---|---|
| hwnd | A handle to the parent window or NULL. |
| rgbDefaultColor | The color initially selected when the dialog box is created. If the specified color value is not among the available colors, the system selects the nearest solid color available. If rgbDefaultColor is zero, the initially selected color is black. |
| lpCustColors | Out. A pointer to an array of 16 values that contain red, green, blue (RGB) values for the custom color boxes in the dialog box. If the user modifies these colors, the system updates the array with the new RGB values. To preserve new custom colors between calls to the AfxChooseColorDialog function, you should allocate static memory for the array. To create a COLORREF color value, use the BGR macro. |
The selected color, or -1 if the user has canceled the dialog.
Control_RunDLL is an undocumented procedure in the Shell32.dll which can be used to launch control panel applications. You’ve to pass the name of the control panel file (.cpl) and the tool represented by it will be launched. For launching some control panel applications, you’ve to provide a valid windows handle (hwnd parameter) and program instance (hInst) parameter).
FUNCTION AfxControlRunDLL (BYVAL hwnd AS HWND, BYVAL hInst AS HINSTANCE, _
BYVAL cmd AS WSTRING PTR, BYVAL nCmdShow AS LONG) AS BOOLEAN
| Parameter | Description |
|---|---|
| hwnd | Handle to a window. This parameter can be NULL. |
| hInst | Instance handle. This parameter can be NULL. |
| cmd | The command and parameters. |
| nCmdShow | Controls how the window is to be shown, e.g. SW_SHOWNORMAL. |
| nCmdShow value | Description |
|---|---|
| SW_FORCEMINIMIZE | Minimizes a window, even if the thread that owns the window is not responding. This flag should only be used when minimizing windows from a different thread. |
| SW_HIDE | Hides the window and activates another window. |
| SW_MAXIMIZE | Maximizes the specified window. |
| SW_MINIMIZE | Minimizes the specified window and activates the next top-level window in the Z order. |
| SW_RESTORE | Activates and displays the window. If the window is minimized or maximized, the system restores it to its original size and position. An application should specify this flag when restoring a minimized window. |
| SW_SHOW | Activates the window and displays it in its current size and position. |
| SW_SHOWDEFAULT | Sets the show state based on the SW_ value specified in the STARTUPINFO structure passed to the CreateProcess function by the program that started the application. |
| SW_SHOWMAXIMIZED | Activates the window and displays it as a maximized window. |
| SW_SHOWMINIMIZED | Activates the window and displays it as a minimized window. |
| SW_SHOWMINNOACTIVE | Displays the window as a minimized window. This value is similar to SW_SHOWMINIMIZED, except the window is not activated. |
| SW_SHOWNA | Displays the window in its current size and position. This value is similar to SW_SHOW, except that the window is not activated. |
| SW_SHOWNOACTIVATE | Displays a window in its most recent size and position. This value is similar to SW_SHOWNORMAL, except that the window is not activated. |
| SW_SHOWNORMAL | Activates and displays a window. If the window is minimized or maximized, the system restores it to its original size and position. An application should specify this flag when displaying the window for the first time. |
AfxControlRunDLL(0, 0, "", SW_SHOWNORMAL) ' Opens the control panel
AfxControlRunDLL(0, 0, "appwiz.cpl", SW_SHOWNORMAL) ' Opens the applications wizard
Creates an Open dialog box that lets the user specify the drive, directory, and the name of a file or set of files to be opened. The dialog box uses the Explorer-style user interface.
FUNCTION AfxOpenFileDialog (BYVAL hwndOwner AS HWND, BYREF wszTitle AS WSTRING, BYREF wszFile AS WSTRING, _
BYREF wszInitialDir AS WSTRING, BYREF wszFilter AS WSTRING, BYREF wszDefExt AS WSTRING, _
BYVAL pdwFlags AS DWORD PTR = NULL, BYVAL pdwBufLen AS DWORD PTR = NULL) AS DWSTRING
| Parameter | Description |
|---|---|
| hwndOwner | A handle to the window that owns the dialog box. This member can be any valid window handle, or it can be NULL if the dialog box has no owner. |
| wszTitle | A string to be placed in the title bar of the dialog box. If this member is NULL, the system uses the default title (that is, Open). |
| wszFile | The file name used to initialize the File Name edit control. |
| wszInitialDir | The initial directory. If no initial directory is specified, the dialog will use the current directory. |
| wszFilter | A buffer containing pairs of “|” separated strings. The first string in each pair is a display string that describes the filter (for example, “Text Files”), and the second string specifies the filter pattern (for example, “*.TXT”). To specify multiple filter patterns for a single display string, use a semicolon to separate the patterns (for example, “*.TXT;*.DOC;*.BAK”). A pattern string can be a combination of valid file name characters and the asterisk (*) wildcard character. Do not include spaces in the pattern string. The system does not change the order of the filters. It displays them in the File Types combo box in the order specified in wszFilter. |
| wszDefExt | The default extension. This extension is appended to the file name if the user fails to type an extension. This string can be any length, but only the first three characters are appended. The string should not contain a period (.). If this member is NULL and the user fails to type an extension, no extension is appended. |
| pdwFlags | [in, out, optional] A set of bit flags you can use to initialize the dialog box. When the dialog box returns, it sets these flags to indicate the user’s input. This member can be a combination of the following flags. |
| pdwBufLen | [in, out, optional] Maximum length of the returned string containing the selected file or files. |
| Flag | Description |
|---|---|
| OFN_ALLOWMULTISELECT | The File Name list box allows multiple selections. |
| OFN_DONTADDTORECENT | Prevents the system from adding a link to the selected file in the file system directory that contains the user’s most recently used documents. To retrieve the location of this directory, call the SHGetSpecialFolderLocation function with the CSIDL_RECENT flag. |
| OFN_EXTENSIONDIFFERENT | The user typed a file name extension that differs from the extension specified by wszDefExt. The function does not use this flag if wszDefExt is NULL. |
| OFN_FILEMUSTEXIST | The user can type only names of existing files in the File Name entry field. If this flag is specified and the user enters an invalid name, the dialog box procedure displays a warning in a message box. If this flag is specified, the OFN_PATHMUSTEXIST flag is also used. |
| OFN_FORCESHOWHIDDEN | Forces the showing of system and hidden files, thus overriding the user setting to show or not show hidden files. However, a file that is marked both system and hidden is not shown. |
| OFN_HIDEREADONLY | Hides the Read Only check box. |
| OFN_NODEREFERENCELINKS | Directs the dialog box to return the path and file name of the selected shortcut (.LNK) file. If this value is not specified, the dialog box returns the path and file name of the file referenced by the shortcut. |
| OFN_NONETWORKBUTTON | Hides and disables the Network button. |
| OFN_NOREADONLYRETURN | The returned file does not have the Read Only check box selected and is not in a write-protected directory. |
| OFN_PATHMUSTEXIST | The user can type only valid paths and file names. If this flag is used and the user types an invalid path and file name in the File Name entry field, the dialog box function displays a warning in a message box. |
| OFN_READONLY | Causes the Read Only check box to be selected initially when the dialog box is created. This flag indicates the state of the Read Only check box when the dialog box is closed. |
| OFN_SHOWHELP | Causes the dialog box to display the Help button. The hwndOwner member must specify the window to receive the HELPMSGSTRING registered messages that the dialog box sends when the user clicks the Help button. |
If the OFN_ALLOWMULTISELECT flag is set and the user selects multiple files, the returned string contains the current directory followed by the file names of the selected files. For Explorer-style dialog boxes, the directory and file name strings are separated by semicolons. If the user selects only one file, the returned string does not have a separator between the path and file name.
Parse the number of “,”. If only one, then the user has selected only a file and the string contains the full path. If more, The first substring contains the path and the others the files. If the user has not selected any file, an empty string is returned. On failure, an empty string is returned and, if not null, the pdwBufLen parameter will be filled by the size of the required buffer in characters.
DIM wszFile AS WSTRING * 260 = "*.*"
DIM wszInitialDir AS STRING * 260 = CURDIR
DIM wszFilter AS WSTRING * 260 = "BAS files (*.BAS)|*.BAS|" & "All Files (*.*)|*.*|"
DIM dwFlags AS DWORD = OFN_EXPLORER OR OFN_FILEMUSTEXIST OR OFN_HIDEREADONLY OR OFN_ALLOWMULTISELECT
DIM dws AS DWSTRING = AfxOpenFileDialog(hwnd, "", wszFile, wszInitialDir, wszFilter, "BAS", @dwFlags, NULL)
Creates a Save dialog box that lets the user specify the drive, directory, and name of a file to save. The dialog box uses the Explorer-style user interface.
FUNCTION AfxSaveFileDialog (BYVAL hwndOwner AS HWND, BYREF wszTitle AS WSTRING, BYREF wszFile AS WSTRING, _
BYREF wszInitialDir AS WSTRING, BYREF wszFilter AS WSTRING, BYREF wszDefExt AS WSTRING, _
BYVAL pdwFlags AS DWORD PTR = NULL) AS DWSTRING
| Parameter | Description |
|---|---|
| hwndOwner | A handle to the window that owns the dialog box. This member can be any valid window handle, or it can be NULL if the dialog box has no owner. |
| wszTitle | A string to be placed in the title bar of the dialog box. If this member is NULL, the system uses the default title (that is, Save As). |
| wszFile | The file name used to initialize the File Name edit control. |
| wszInitialDir | The initial directory. If no initial directory is specified, the dialog will use the current directory. |
| wszFilter | A buffer containing pairs of “|” separated strings. The first string in each pair is a display string that describes the filter (for example, “Text Files”), and the second string specifies the filter pattern (for example, “*.TXT”). To specify multiple filter patterns for a single display string, use a semicolon to separate the patterns (for example, “*.TXT;*.DOC;*.BAK”). A pattern string can be a combination of valid file name characters and the asterisk (*) wildcard character. Do not include spaces in the pattern string. The system does not change the order of the filters. It displays them in the File Types combo box in the order specified in wszFilter. |
| wszDefExt | The default extension. This extension is appended to the file name if the user fails to type an extension. This string can be any length, but only the first three characters are appended. The string should not contain a period (.). If this member is NULL and the user fails to type an extension, no extension is appended. |
| pdwFlags | [in, out, optional] A set of bit flags you can use to initialize the dialog box. When the dialog box returns, it sets these flags to indicate the user’s input. This member can be a combination of the following flags. |
| Flag | Description |
|---|---|
| OFN_CREATEPROMPT | If the user specifies a file that does not exist, this flag causes the dialog box to prompt the user for permission to create the file. If the user chooses to create the file, the dialog box closes and the function returns the specified name; otherwise, the dialog box remains open. |
| OFN_DONTADDTORECENT | Prevents the system from adding a link to the selected file in the file system directory that contains the user’s most recently used documents. To retrieve the location of this directory, call the SHGetSpecialFolderLocation function with the CSIDL_RECENT flag. |
| OFN_EXTENSIONDIFFERENT | The user typed a file name extension that differs from the extension specified by wszDefExt. The function does not use this flag if wszDefExt is NULL. |
| OFN_FORCESHOWHIDDEN | Forces the showing of system and hidden files, thus overriding the user setting to show or not show hidden files. However, a file that is marked both system and hidden is not shown. |
| OFN_HIDEREADONLY | Hides the Read Only check box |
| OFN_NOCHANGEDIR | Restores the current directory to its original value if the user changed the directory while searching for files. |
| OFN_NODEREFERENCELINKS | Directs the dialog box to return the path and file name of the selected shortcut (.LNK) file. If this value is not specified, the dialog box returns the path and file name of the file referenced by the shortcut. |
| OFN_NOTESTFILECREATE | The file is not created before the dialog box is closed. This flag should be specified if the application saves the file on a create-nonmodify network share. When an application specifies this flag, the library does not check for write protection, a full disk, an open drive door, or network protection. Applications using this flag must perform file operations carefully, because a file cannot be reopened once it is closed. |
| OFN_NONETWORKBUTTON | Hides and disables the Network button. |
| OFN_NOREADONLYRETURN | The returned file does not have the Read Only check box selected and is not in a write-protected directory. |
| OFN_OVERWRITEPROMPT | The user can type only valid paths and file names. If this flag is used and the user types an invalid path and file name in the File Name entry field, the dialog box function displays a warning in a message box. |
| OFN_PATHMUSTEXIST | The user can type only valid paths and file names. If this flag is used and the user types an invalid path and file name in the File Name entry field, the dialog box function displays a warning in a message box. |
| OFN_SHOWHELP | Causes the dialog box to display the Help button. The hwndOwner member must specify the window to receive the HELPMSGSTRING registered messages that the dialog box sends when the user clicks the Help button. |
The path of the file to be saved.
DIM wszFile AS WSTRING * 260 = "*.*"
DIM wszInitialDir AS STRING * 260 = CURDIR
DIM wszFilter AS WSTRING * 260 = "BAS files (*.BAS)|*.BAS|" & "All Files (*.*)|*.*|"
DIM dwFlags AS DWORD = OFN_EXPLORER OR OFN_FILEMUSTEXIST OR OFN_HIDEREADONLY OR OFN_OVERWRITEPROMPT
DIM dws AS DWSTRING = AfxSaveFileDialog(hwnd, "", wszFile, wszInitialDir, wszFilter, "BAS", @dwFlags)
Displays the Windows Information System dialog.
FUNCTION AfxShowSysInfo (BYVAL hwnd AS HWND) AS BOOLEAN
| Parameter | Description |
|---|---|
| hwnd | A handle to the parent window or NULL. |
If the function succeeds, the return value is TRUE. If the function fails, the return value is FALSE.
Returns the horizontal scaling of the monitor that the window is currently displayed on.
FUNCTION AfxGetMonitorHorizontalScaling (BYVAL hwnd AS HWND = NULL) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Optional. A handle to the window. If NULL, the desktop window handle will be used. |
If the application to which the window belongs is not DPI aware, a computer using 192 DPI, will return an scaling ratio of 2.
Returns the vertical scaling of the monitor that the window is currently displayed on.
FUNCTION AfxGetMonitorVerticalScaling (BYVAL hwnd AS HWND = NULL) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Optional. A handle to the window. If NULL, the desktop window handle will be used. |
If the application to which the window belongs is not DPI aware, a computer using 192 DPI, will return an scaling ratio of 2.
Returns the logical height of the monitor that the window is currently displayed on.
FUNCTION AfxGetMonitorLogicalHeight (BYVAL hwnd AS HWND = NULL) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Optional. A handle to the window. If NULL, the desktop window handle will be used. |
If the application to which the window belongs is not DPI aware, a monitor with an height resolution of 1080 pixels in a computer using 192 DPI, will return 540 pixels.
Returns the logical width of the monitor that the window is currently displayed on.
FUNCTION AfxGetMonitorLogicalWidth (BYVAL hwnd AS HWND = NULL) AS DWORD
| Parameter | Description |
|---|---|
| hwnd | Optional. A handle to the window. If NULL, the desktop window handle will be used. |
If the application to which the window belongs is not DPI aware, a monitor with a width resolution of 1920 pixels in a computer using 192 DPI, will return 960 pixels.
Determines if screen resolution meets minimum requirements in relative pixels, e.g. for a screen resolution of 1920x1080 pixels and a DPI of 192 (scaling ratio = 2), the maximum relative pixels for a DPI aware application is 960x540.
FUNCTION AfxIsDPIResolutionAtLeast (BYVAL cxMin AS LONG, BYVAL cyMin AS LONG) AS BOOLEAN
| Parameter | Description |
|---|---|
| cxMin | Minimum screen resolution width in relative pixels. |
| cyMin | Minimum screen resolution height in relative pixels. |
TRUE or FALSE.
Determines whether the current process is dots per inch (dpi) aware such that it adjusts the sizes of UI elements to compensate for the dpi setting.
FUNCTION AfxIsProcessDPIAware () AS BOOLEAN
TRUE if the process is dpi aware; otherwise, FALSE.
Determines if screen resolution meets minimum requirements.
FUNCTION AfxIsResolutionAtLeast (BYVAL cxMin AS LONG, BYVAL cyMin AS LONG) AS BOOLEAN
| Parameter | Description |
|---|---|
| cxMin | Minimum screen resolution width in relative pixels. |
| cyMin | Minimum screen resolution height in relative pixels. |
TRUE or FALSE.
Loads a specified icon resource with a client-specified system metric.
FUNCTION AfxLoadIconMetric (BYVAL hinst AS HINSTANCE, BYVAL pwszName AS WSTRING PTR, _
BYVAL lims AS LONG, BYVAL phico AS HICON PTR) AS HRESULT
| Parameter | Description |
|---|---|
| hinst | A handle to the module of either a DLL or executable (.exe) file that contains the icon to be loaded. For more information, see GetModuleHandle. To load a predefined icon or a standalone icon file, set this parameter to NULL. |
| pwszName | A pointer to a null-terminated, Unicode buffer that contains
location information about the icon to load. It is interpreted as
follows: If hinst is NULL, pwszName can specify one of
two things. 1) The identifier of a predefined icon to load. These identifiers are recognized: IDI_APPLICATION, IDI_INFORMATION, IDI_ERROR, IDI_WARNING, IDI_SHIELD, IDI_QUESTION. To pass these constants to the AfxLoadIconMetric function, use the MAKEINTRESOURCE macro. For example, to load the IDI_ERROR icon, pass MAKEINTRESOURCE(IDI_ERROR) as the pwszName parameter and NULL as the hinst parameter. 2) The name of a standalone icon (.ico) file. If hinst is non-null, pwszName can specify one of two things. 1) The name of the icon resource, if the icon resource is to be loaded by name from the module. 2) The icon ordinal, if the icon resource is to be loaded by ordinal from the module. This ordinal must be packaged by using the MAKEINTRESOURCE macro. |
| lims | The desired metric. One of the following
values: LIM_SMALL : Corresponds to SM_CXSMICON, the recommended pixel width of a small icon. LIM_LARGE : Corresponds to SM_CXICON, the default pixel width of an icon. |
| phico | When this function returns, contains a pointer to the handle of the loaded icon. |
Returns S_OK if successful, otherwise an error, including the following value: E_INVALIDARG : The contents of the buffer pointed to by pszName do not fit any of the expected interpretations.
LoadIconMetric is similar to LoadIcon, but with the capability to specify the icon metric. It is used in place of LoadIcon when the calling application wants to ensure a high quality icon. This is particularly useful in high dots per inch (dpi) situations.
Icons are extracted or created as follows.
Retrieves the number of pixels per logical inch along the screen width. In a system with multiple display monitors, this value is the same for all monitors. Aliases: AfxGetDpi, AfxGetDpiX.
FUNCTION AfxLogPixelsX () AS LONG
FUNCTION AfxGetDpi () AS LONG
FUNCTION AfxGetDpiX () AS LONG
Retrieves the number of pixels per logical inch along the screen height. In a system with multiple display monitors, this value is the same for all monitors. Alias: AfxGetDpiY.
FUNCTION AfxLogPixelsY () AS LONG
FUNCTION AfxGetDpiY () AS LONG
Retrieves the desktop horizontal scaling ratio.
FUNCTION AfxScaleRatioX () AS LONG
Retrieves the desktop vertical scaling ratio.
FUNCTION AfxScaleRatioY () AS LONG
Scales an horizontal coordinate according the DPI (dots per pixel) being used by the operating system.
FUNCTION AfxScaleX (BYVAL cx AS SINGLE) AS SINGLE
The scaled coordinate.
Scales a vertical coordinate according the DPI (dots per pixel) being used by the operating system.
FUNCTION AfxScaleY (BYVAL cx AS SINGLE) AS SINGLE
The scaled coordinate.
Sets the current process as dots per inch (dpi) aware.
Note: AfxSetProcessDPIAware is subject to a possible race condition if a DLL caches dpi settings during initialization. For this reason, it is recommended that dpi-aware be set through the application (.exe) manifest rather than by calling AfxSetProcessDPIAware.
FUNCTION AfxSetProcessDPIAware () AS BOOLEAN
If the function succeeds, the return value is TRUE. Otherwise, the return value is FALSE.
DLLs should accept the dpi setting of the host process rather than call AfxSetProcessDPIAware themselves. To be set properly, dpiAware should be specified as part of the application (.exe) manifest. (dpiAware defined in an embedded DLL manifest has no affect.) The following markup shows how to set dpiAware as part of an application (.exe) manifest.
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0" xmlns:asmv3="urn:schemas-microsoft-com:asm.v3" >
...
<asmv3:application>
<asmv3:windowsSettings xmlns="http://schemas.microsoft.com/SMI/2005/WindowsSettings">
<dpiAware>true</dpiAware>
</asmv3:windowsSettings>
</asmv3:application>
...
</assembly>
Unscales an horizontal coordinate according the DPI (dots per pixel) being used by the operating system.
FUNCTION AfxUnscaleX (BYVAL cx AS SINGLE) AS SINGLE
| Parameter | Description |
|---|---|
| cx | The value of the horizontal coordinate, in pixels. |
The unscaled coordinate.
Unscales a vertical coordinate according the DPI (dots per pixel) being used by the operating system.
FUNCTION AfxUnscaleY (BYVAL cx AS SINGLE) AS SINGLE
| Parameter | Description |
|---|---|
| cy | The value of the vertical coordinate, in pixels. |
The unscaled coordinate.
Returns TRUE if the OS uses DPI scaling; FALSE otherwise.
FUNCTION AfxUseDpiScaling () AS BOOLEAN
Creates a logical font.
FUNCTION AfxCreateFont (BYREF wszFaceName AS WSTRING, BYVAL lPointSize AS LONG, BYVAL DPI AS LONG = 96, _
BYVAL lWeight AS LONG = 0, BYVAL bItalic AS UBYTE = FALSE, BYVAL bUnderline AS UBYTE = FALSE, _
BYVAL bStrikeOut AS UBYTE = FALSE, BYVAL bCharSet AS UBYTE = DEFAULT_CHARSET) AS HFONT
| Parameter | Description |
|---|---|
| wszFaceName | The typeface name. |
| lPointSize | The point size. |
| DPI | Dots per inch to calculate scaling. Default value = 96 (no scaling). If you pass -1 and the application is DPI aware, the DPI value used by the operating system will be used. |
| lWeight | Initial weight of the font. If the weight is below 550 (the average
of FW_NORMAL, 400, and FW_BOLD, 700), then the Bold property is also
initialized to FALSE. If the weight is above 550, the Bold property is
set to TRUE. The following values are defined for convenience: FW_DONTCARE (0), FW_THIN (100), FW_EXTRALIGHT (200), FW_ULTRALIGHT (200), FW_LIGHT (300), FW_NORMAL (400), FW_REGULAR (400), FW_MEDIUM (500), FW_SEMIBOLD (600), FW_DEMIBOLD (600), FW_BOLD (700), FW_EXTRABOLD (800), FW_ULTRABOLD (800), FW_HEAVY (900), FW_BLACK (900) |
| bItalic | Italic flag. CTRUE or FALSE. |
| bUnderline | Underline flag. CTRUE or FALSE. |
| bStrikeOut | StrikeOut flag. CTRUE or FALSE |
| bCharSet | Specifies the character set. The following values are
predefined: ANSI_CHARSET, BALTIC_CHARSET, CHINESEBIG5_CHARSET, DEFAULT_CHARSET, EASTEUROPE_CHARSET, GB2312_CHARSET, GREEK_CHARSET, HANGUL_CHARSET, MAC_CHARSET, OEM_CHARSET, RUSSIAN_CHARSET, SHIFTJIS_CHARSET, SYMBOL_CHARSET, TURKISH_CHARSET. Korean Windows: JOHAB_CHARSET. Middle-Eastern Windows: HEBREW_CHARSET, ARABIC_CHARSET. Thai Windows: THAI_CHARSET. The OEM_CHARSET value specifies a character set that is operating-system dependent. DEFAULT_CHARSET is set to a value based on the current system locale. For example, when the system locale is English (United States), it is set as ANSI_CHARSET. Fonts with other character sets may exist in the operating system. If an application uses a font with an unknown character set, it should not attempt to translate or interpret strings that are rendered with that font. This parameter is important in the font mapping process. To ensure consistent results, specify a specific character set. If you specify a typeface name in the wszFaceName parameter, make sure that the bCharSet value matches the character set of the typeface specified in wszFaceName. |
The handle of the font or NULL on failure.
The returned font must be destroyed with DeleteObject or the macro DeleteFont when no longer needed to prevent memory leaks.
hFont = AfxCreateFont("MS Sans Serif", 8, , FW_NORMAL, , , , DEFAULT_CHARSET)
hFont = AfxCreateFont("Courier New", 10, 96 , FW_BOLD, , , , DEFAULT_CHARSET)
hFont = AfxCreateFont("Marlett", 8, -1, FW_NORMAL, , , , SYMBOL_CHARSET)
Returns the logical height of a font given its point size.
FUNCTION AfxGetFontHeight (BYVAL nPointSize AS LONG) AS LONG
| Parameter | Description |
|---|---|
| nPointSize | The point size of the font. |
Returns the point size of a font given its logical height.
FUNCTION AfxGetFontPointSize (BYVAL nHeight AS LONG) AS LONG
| Parameter | Description |
|---|---|
| nHeight | The logical height of the font. |
Retrieves the font with which the window or control is currently drawing its text.
FUNCTION AfxGetWindowFont (BYVAL hwnd AS HWND) AS HFONT
| Parameter | Description |
|---|---|
| hwnd | A handle to a window or control. |
The handle of the font.
Retrieves information about the font being used by a window or control.
FUNCTION AfxGetWindowFontInfo (BYVAL hwnd AS HWND) AS LOGFONTW
| Parameter | Description |
|---|---|
| hwnd | A handle to a window or control. |
A LOGFONTW structure.
Retrieves information about the fonts used by Windows.
FUNCTION AfxGetWindowsFontInfo (BYVAL nType AS LONG, BYVAL plfw AS LOGFONTW PTR) AS BOOLEAN
| Parameter | Description |
|---|---|
| nType | The type of the font: AFX_FONT_CAPTION, AFX_FONT_SMALLCAPTION, AFX_FONT_MENU, AFX_FONT_STATUS, AFX_FONT_MESSAGE. |
| plfw | Pointer to a LOGFONTW structure that receives the font information. |
TRUE on succes or FALSE on failure. To get extended error information, call GetLastError.
Retrieves the point size of the fonts used by Windows.
FUNCTION AfxGetWindowsFontPointSize (BYVAL nType AS LONG) AS LONG
| Parameter | Description |
|---|---|
| nType | The type of the font: AFX_FONT_CAPTION, AFX_FONT_SMALLCAPTION, AFX_FONT_MENU, AFX_FONT_STATUS, AFX_FONT_MESSAGE. |
Modifies the face name of the font of a window or control.
FUNCTION AfxModifyFontFaceName (BYVAL hwnd AS HWND, BYREF wszNewFaceName AS WSTRING) AS HFONT
| Parameter | Description |
|---|---|
| hwnd | Handle to the window or control. |
| wszNewFaceName | The new face name of the font. |
The handle of the new font on success, or NULL on failure.
To get extended error information call GetLastError.
The returned font must be destroyed with DeleteObject or the macro DeleteFont when no longer needed to prevent memory leaks.
Modifies the height of the font used by a window of control.
FUNCTION AfxModifyFontHeight (BYVAL hwnd AS HWND, BYVAL nValue AS LONG) AS HFONT
| Parameter | Description |
|---|---|
| hwnd | Handle to the window or control. |
| nValue | The base is 100. To increase the font a 20% pass 120; to reduce it a 20% pass 80%. |
The handle of the new font on success, or NULL on failure.
To get extended error information call GetLastError.
The returned font must be destroyed with DeleteObject or the macro DeleteFont when no longer needed to prevent memory leaks.
Modifies settings of the font used by a window of control.
FUNCTION AfxModifyFontSettings (BYVAL hwnd AS HWND, BYVAL nSetting AS LONG, BYVAL nValue AS LONG) AS HFONT
| Parameter | Description |
|---|---|
| hwnd | Handle to the window or control. |
| nSetting | One of the AFX_FONT_xxx constants (see below). |
| nValue | Depends of the nSetting value. AFX_FONT_HEIGHT :
The base is 100. To increase the font a 20% pass 120; to reduce it a 20%
pass 80%. AFX_FONT_WEIGHT : The weight of the font in the range 0 through 1000. For example, 400 is normal and 700 is bold. If this value is zero, a default weight is used. The following values are defined for convenience. FW_DONTCARE (0), FW_THIN (100), FW_EXTRALIGHT (200), FW_ULTRALIGHT (200), FW_LIGHT (300), FW_NORMAL (400), FW_REGULAR (400), FW_MEDIUM (500), FW_SEMIBOLD (600), FW_DEMIBOLD (600), FW_BOLD (700), FW_EXTRABOLD (800), FW_ULTRABOLD (800), FW_HEAVY (900), FW_BLACK (900) AFX_FONT_ITALIC : TRUE or FALSE. AFX_FONT_UNDERLINE : TRUE or FALSE. AFX_FONT_STRIKEOUT : TRUE or FALSE. AFX_FONT_CHARSET: The following values are predefined: ANSI_CHARSET, BALTIC_CHARSET, CHINESEBIG5_CHARSET, DEFAULT_CHARSET, EASTEUROPE_CHARSET, GB2312_CHARSET, GREEK_CHARSET, HANGUL_CHARSET, MAC_CHARSET, OEM_CHARSET, RUSSIAN_CHARSET, SHIFTJIS_CHARSET, SYMBOL_CHARSET, TURKISH_CHARSET, VIETNAMESE_CHARSET, JOHAB_CHARSET (Korean language edition of Windows), ARABIC_CHARSET and HEBREW_CHARSET (Middle East language edition of Windows), THAI_CHARSET (Thai language edition of Windows). The OEM_CHARSET value specifies a character set that is operating-system dependent. DEFAULT_CHARSET is set to a value based on the current system locale. For example, when the system locale is English (United States), it is set as ANSI_CHARSET. |
The handle of the new font on success, or NULL on failure.
To get extended error information call GetLastError.
The returned font must be destroyed with DeleteObject or the macro DeleteFont when no longer needed to prevent memory leaks.
Sets the font that a control is to use when drawing text.
SUB AfxSetWindowFont (BYVAL hwnd AS HWND, BYVAL hFont AS HFONT, BYVAL fRedraw AS LONG = CTRUE)
| Parameter | Description |
|---|---|
| hwnd | Handle to the window or control. |
| hFont | A handle to the font. If this parameter is NULL, the control uses the default system font to draw text. |
| fRedraw | Optional. Specifies whether the control should be redrawn immediately upon setting the font. If this parameter is CTRUE, the control redraws itself. |
The handle of the new font on success, or NULL on failure.
To get extended error information call GetLastError.
The application should call the DeleteObject function to delete the font when it is no longer needed; for example, after it destroys the control.
The size of the control does not change as a result of receiving this message. To avoid clipping text that does not fit within the boundaries of the control, the application should correct the size of the control window before it sets the font.
Clears the contents of the clipboard.
FUNCTION AfxClearClipboard () AS LONG
If the function succeeds, the return value is nonzero. If the function fails, the return value is zero.
Retrieves data from the clipboard in the specified format.
FUNCTION AfxGetClipboardData (BYVAL cfFormat AS DWORD) AS HGLOBAL
| Parameter | Description |
|---|---|
| cfFormat | The clipboard format. This parameter can be a registered format or any of the standard clipboard formats. |
Standard clipboard formats:
| Constant/Value | Description |
|---|---|
| CF_BITMAP | A handle to a bitmap. |
| CF_DIB | A memory object containing a BITMAPINFO structure followed by the bitmap bits. |
| CF_DIBV5 | A memory object containing a BITMAPV5HEADER structure followed by the bitmap color space information and the bitmap bits. |
| CF_DIF | Software Arts’ Data Interchange Format. |
| CF_DSPBITMAP | Bitmap display format associated with a private format. The hMem parameter must be a handle to data that can be displayed in bitmap format in lieu of the privately formatted data. |
| CF_DSPENHMETAFILE | Enhanced metafile display format associated with a private format. The hMem parameter must be a handle to data that can be displayed in enhanced metafile format in lieu of the privately formatted data. |
| CF_DSPMETAFILEPICT | Metafile-picture display format associated with a private format. The hMem parameter must be a handle to data that can be displayed in metafile-picture format in lieu of the privately formatted data. |
| CF_DSPTEXT | Text display format associated with a private format. The hMem parameter must be a handle to data that can be displayed in text format in lieu of the privately formatted data. |
| CF_ENHMETAFILE | A handle to an enhanced metafile. |
| CF_GDIOBJFIRST | Start of a range of integer values for application-defined GDI object clipboard formats. The end of the range is CF_GDIOBJLAST. Handles associated with clipboard formats in this range are not automatically deleted using the GlobalFree function when the clipboard is emptied. Also, when using values in this range, the hMem parameter is not a handle to a GDI object, but is a handle allocated by the GlobalAlloc function with the GMEM_MOVEABLE flag. |
| CF_GDIOBJLAST | See CF_GDIOBJFIRST. |
| CF_HDROP | A handle that identifies a list of files. An application can retrieve information about the files by passing the handle to the DragQueryFile function. |
| CF_LOCALE | The data is a handle to the locale identifier associated with text
in the clipboard. When you close the clipboard, if it contains CF_TEXT
data but no CF_LOCALE data, the system automatically sets the CF_LOCALE
format to the current input language. You can use the CF_LOCALE format
to associate a different locale with the clipboard text. An application that pastes text from the clipboard can retrieve this format to determine which character set was used to generate the text. Note that the clipboard does not support plain text in multiple character sets. To achieve this, use a formatted text data type such as RTF instead. The system uses the code page associated with CF_LOCALE to implicitly convert from CF_TEXT to CF_UNICODETEXT. Therefore, the correct code page table is used for the conversion. |
| CF_METAFILEPICT | Handle to a metafile picture format as defined by the METAFILEPICT structure. When passing a CF_METAFILEPICT handle by means of DDE, the application responsible for deleting hMem should also free the metafile referred to by the CF_METAFILEPICT handle. |
| CF_OEMTEXT | Text format containing characters in the OEM character set. Each line ends with a carriage return/linefeed (CR-LF) combination. A null character signals the end of the data. |
| CF_OWNERDISPLAY | Owner-display format. The clipboard owner must display and update the clipboard viewer window, and receive the WM_ASKCBFORMATNAME, WM_HSCROLLCLIPBOARD, WM_PAINTCLIPBOARD, WM_SIZECLIPBOARD, and WM_VSCROLLCLIPBOARD messages. The hMem parameter must be NULL. |
| CF_PALETTE | Handle to a color palette. Whenever an application places data in
the clipboard that depends on or assumes a color palette, it should
place the palette on the clipboard as well. If the clipboard contains data in the CF_PALETTE (logical color palette) format, the application should use the** SelectPalette** and RealizePalette functions to realize (compare) any other data in the clipboard against that logical palette. When displaying clipboard data, the clipboard always uses as its current palette any object on the clipboard that is in the CF_PALETTE format. |
| CF_PENDATA | Data for the pen extensions to the Microsoft Windows for Pen Computing. |
| CF_PRIVATEFIRST | Start of a range of integer values for private clipboard formats. The range ends with CF_PRIVATELAST. Handles associated with private clipboard formats are not freed automatically; the clipboard owner must free such handles, typically in response to the WM_DESTROYCLIPBOARD message. |
| CF_PRIVATELAST | See CF_PRIVATEFIRST. |
| CF_RIFF | Represents audio data more complex than can be represented in a CF_WAVE standard wave format. |
| CF_SYLK | Microsoft Symbolic Link (SYLK) format. |
| CF_TEXT | Text format. Each line ends with a carriage return/linefeed (CR-LF) combination. A null character signals the end of the data. Use this format for ANSI text. |
| CF_TIFF | Tagged-image file format. |
| CF_UNICODETEXT | Unicode text format. Each line ends with a carriage return/linefeed (CR-LF) combination. A null character signals the end of the data. |
| CF_WAVE | Represents audio data in one of the standard wave formats, such as 11 kHz or 22 kHz PCM. |
If the function succeeds, the return value is the handle to the data. If the function fails, the return value is NULL.
Returns a text string from the clipboard.
FUNCTION AfxGetClipboardText () AS DWSTRING
The retrieved text string.
Places data on the clipboard in a specified clipboard format.
FUNCTION AfxSetClipboardData (BYVAL cfFormat AS DWORD, BYVAL hData AS HANDLE) AS HANDLE
| Parameter | Description |
|---|---|
| cfFormat | The clipboard format. This parameter can be a registered format or any of the standard clipboard formats. |
| hData | Handle to the data in the specified format. |
Standard clipboard formats:
| Constant/Value | Description |
|---|---|
| CF_BITMAP | A handle to a bitmap. |
| CF_DIB | A memory object containing a BITMAPINFO structure followed by the bitmap bits. |
| CF_DIBV5 | A memory object containing a BITMAPV5HEADER structure followed by the bitmap color space information and the bitmap bits. |
| CF_DIF | Software Arts’ Data Interchange Format. |
| CF_DSPBITMAP | Bitmap display format associated with a private format. The hMem parameter must be a handle to data that can be displayed in bitmap format in lieu of the privately formatted data. |
| CF_DSPENHMETAFILE | Enhanced metafile display format associated with a private format. The hMem parameter must be a handle to data that can be displayed in enhanced metafile format in lieu of the privately formatted data. |
| CF_DSPMETAFILEPICT | Metafile-picture display format associated with a private format. The hMem parameter must be a handle to data that can be displayed in metafile-picture format in lieu of the privately formatted data. |
| CF_DSPTEXT | Text display format associated with a private format. The hMem parameter must be a handle to data that can be displayed in text format in lieu of the privately formatted data. |
| CF_ENHMETAFILE | A handle to an enhanced metafile. |
| CF_GDIOBJFIRST | Start of a range of integer values for application-defined GDI object clipboard formats. The end of the range is CF_GDIOBJLAST. Handles associated with clipboard formats in this range are not automatically deleted using the GlobalFree function when the clipboard is emptied. Also, when using values in this range, the hMem parameter is not a handle to a GDI object, but is a handle allocated by the GlobalAlloc function with the GMEM_MOVEABLE flag. |
| CF_GDIOBJLAST | See CF_GDIOBJFIRST. |
| CF_HDROP | A handle that identifies a list of files. An application can retrieve information about the files by passing the handle to the DragQueryFile function. |
| CF_LOCALE | The data is a handle to the locale identifier associated with text
in the clipboard. When you close the clipboard, if it contains CF_TEXT
data but no CF_LOCALE data, the system automatically sets the CF_LOCALE
format to the current input language. You can use the CF_LOCALE format
to associate a different locale with the clipboard text. An application that pastes text from the clipboard can retrieve this format to determine which character set was used to generate the text. Note that the clipboard does not support plain text in multiple character sets. To achieve this, use a formatted text data type such as RTF instead. The system uses the code page associated with CF_LOCALE to implicitly convert from CF_TEXT to CF_UNICODETEXT. Therefore, the correct code page table is used for the conversion. |
| CF_METAFILEPICT | Handle to a metafile picture format as defined by the METAFILEPICT structure. When passing a CF_METAFILEPICT handle by means of DDE, the application responsible for deleting hMem should also free the metafile referred to by the CF_METAFILEPICT handle. |
| CF_OEMTEXT | Text format containing characters in the OEM character set. Each line ends with a carriage return/linefeed (CR-LF) combination. A null character signals the end of the data. |
| CF_OWNERDISPLAY | Owner-display format. The clipboard owner must display and update the clipboard viewer window, and receive the WM_ASKCBFORMATNAME, WM_HSCROLLCLIPBOARD, WM_PAINTCLIPBOARD, WM_SIZECLIPBOARD, and WM_VSCROLLCLIPBOARD messages. The hMem parameter must be NULL. |
| CF_PALETTE | Handle to a color palette. Whenever an application places data in
the clipboard that depends on or assumes a color palette, it should
place the palette on the clipboard as well. If the clipboard contains data in the CF_PALETTE (logical color palette) format, the application should use the** SelectPalette** and RealizePalette functions to realize (compare) any other data in the clipboard against that logical palette. When displaying clipboard data, the clipboard always uses as its current palette any object on the clipboard that is in the CF_PALETTE format. |
| CF_PENDATA | Data for the pen extensions to the Microsoft Windows for Pen Computing. |
| CF_PRIVATEFIRST | Start of a range of integer values for private clipboard formats. The range ends with CF_PRIVATELAST. Handles associated with private clipboard formats are not freed automatically; the clipboard owner must free such handles, typically in response to the WM_DESTROYCLIPBOARD message. |
| CF_PRIVATELAST | See CF_PRIVATEFIRST. |
| CF_RIFF | Represents audio data more complex than can be represented in a CF_WAVE standard wave format. |
| CF_SYLK | Microsoft Symbolic Link (SYLK) format. |
| CF_TEXT | Text format. Each line ends with a carriage return/linefeed (CR-LF) combination. A null character signals the end of the data. Use this format for ANSI text. |
| CF_TIFF | Tagged-image file format. |
| CF_UNICODETEXT | Unicode text format. Each line ends with a carriage return/linefeed (CR-LF) combination. A null character signals the end of the data. |
| CF_WAVE | Represents audio data in one of the standard wave formats, such as 11 kHz or 22 kHz PCM. |
If the function succeeds, the return value is the handle to the data. If the function fails, the return value is NULL.
If AfxSetClipboardData succeeds, the system owns the object identified by the hData parameter. The application may not write to or free the data once ownership has been transferred to the system.
Places a text string into the clipboard.
FUNCTION AfxSetClipboardText (BYREF wszText AS WSTRING) AS HANDLE
| Parameter | Description |
|---|---|
| wszText | The text to be placed in the clipboard. |
If the function succeeds, the return value is the handle to the data. If the function fails, the return value is NULL.
Captures the display and returns an handle to a bitmap.
FUNCTION AfxCaptureDisplay () AS HBITMAP
The handle of a bitmap.
DIM hBitmap AS HBITMAP = AfxCaptureDisplay
Retrieves the height of the specified bitmap.
FUNCTION AfxGetBitmapHeight (BYVAL hBitmap AS HBITMAP) AS LONG
| Parameter | Description |
|---|---|
| hBitmap | Handle to the bitmap. |
The height of the bitmap on success or 0 on failure.
Retrieves the width of the specified bitmap.
FUNCTION AfxGetBitmapWidth (BYVAL hBitmap AS HBITMAP) AS LONG
| Parameter | Description |
|---|---|
| hBitmap | Handle to the bitmap. |
The width of the bitmap on success or 0 on failure.
Creates a DIB section.
FUNCTION AfxCreateDIBSection (BYVAL hdc AS HDC, BYVAL nWidth AS DWORD, BYVAL nHeight AS DWORD, _
BYVAL bpp AS LONG = 0, BYVAL ppvBits AS ANY PTR PTR = NULL) AS HBITMAP
| Parameter | Description |
|---|---|
| hdc | A handle to the device context. |
| nWidth | The width of the bitmap, in pixels. |
| nHeight | The height of the bitmap, in pixels. |
| bpp | The number of bits-per-pixel. If this parameter is 0, the function will use the value returned by GetDeviceCaps(hDC, BITSPIXEL_). |
| ppvBits | Out, optional. A pointer to a variable that receives a pointer to the location of the DIB bit values. Can be NULL. |
If the function succeeds, the return value is a handle to the newly created DIB, and ppvBits points to the bitmap bit values.
If the function fails, the return value is NULL, and ppvBits is NULL. The function can fail if one or more of the input parameters is invalid.
This function can return the following value: ERROR_INVALID_PARAMETER (One or more of the input parameters is invalid).
You must delete the returned bitmap handle with DeleteObject when no longer needed to avoid memory leaks.
You cannot paste a DIB section from one application into another application.
AfxCreateDIBSection does not use the BITMAPINFOHEADER parameters biXPelsPerMeter or biYPelsPerMeter and will not provide resolution information in the BITMAPINFO structure.
DIM hdcWindow AS HDC, hbmp AS HBITMAP, pvBits AS ANY PTR
hdcWindow = GetWindowDC(hwnd) ' where hwnd is the handle of the wanted window or control
hbmp = AfxCreateDIBSection(hdcWindow, 10, 10, @pvBits)
ReleaseDC(hwnd, hdcWindow)
Centers a window on the screen or over another window. It also ensures that the placement is done within the work area.
SUB AfxCenterWindow (BYVAL hwnd AS HWND = NULL, BYVAL hwndParent AS HWND = NULL)
| Parameter | Description |
|---|---|
| hwnd | Optional. Handle to the window. |
| hwndParent | Optional. Handle to the parent window. |
Brings the thread that created the specified window into the foreground and activates the window. Keyboard input is directed to the window, and various visual cues are changed for the user. The system assigns a slightly higher priority to the thread that created the foreground window than it does to other threads.
SUB AfxForceSetForegroundWindow (BYVAL hwnd AS HWND)
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
Replacement for the SetForegroundWindow API function, that sometimes fails.
Retrieves information about the current system.
FUNCTION AfxGetSystemInfo (BYREF metricName AS STRING) AS LONG_PTR
| MetricName | Description |
|---|---|
| CpuCount | The number of logical processors in the current group. |
| CpuMask | A mask representing the set of processors configured into the system. Bit 0 is processor 0; bit 31 is processor 31. |
| Granularity | The granularity for the starting address at which virtual memory can be allocated. |
| MaxAppAddr | The highest memory address accessible to applications and DLLs. |
| MaxAppAddr | The lowest memory address accessible to applications and DLLs. |
| PageSize | The page size and the granularity of page protection and commitment. This is the page size used by the VirtualAlloc function. |
Retrieves the handle of the enabled and visible window at the top of the z-order in an application.
FUNCTION AfxGetTopEnabledWindow () AS HWND
Handle of the window at top of z-order or NULL.
Retrieves the window’s top-level parent window.
FUNCTION AfxGetTopEnabledWindow () AS HWND
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
Handle of the top-level parent window.
Retrieves the window’s top-level parent or owner window.
FUNCTION AfxGetTopLevelWindow (BYVAL hwnd AS HWND) AS HWND
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
Handle of the top-level parent or owner window.
Retrieves the bounds of a window without the drop shadows.
FUNCTION AfxGetWindowBounds (BYVAL hWin AS HWND) AS RECT
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
In Windows Vista and later, the Window Rect includes the area occupied by the drop shadow. Calling GetWindowRect will have different behavior depending on whether the window has ever been shown or not. If the window has not been shown before, GetWindowRect will not include the area of the drop shadow. To get the window bounds excluding the drop shadow, use DwmGetWindowAttribute, specifying DWMWA_EXTENDED_FRAME_BOUNDS. Note that unlike the Window Rect, the DWM Extended Frame Bounds are not adjusted for DPI. Getting the extended frame bounds can only be done after the window has been shown at least once.
Retrieves the name of the class to which the specified window belongs.
FUNCTION AfxGetWindowClassName (BYVAL hwnd AS HWND) AS DWSTRING
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
The name of the class.
Returns the height of the client area of window, in pixels.
FUNCTION AfxGetWindowClientHeight (BYVAL hwnd AS HWND) AS LONG
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
Retrieves the coordinates of a window’s client area. The client coordinates specify the upper-left and lower-right corners of the client area. Because client coordinates are relative to the upper-left corner of a window’s client area, the coordinates of the upper-left corner are (0,0).
FUNCTION AfxGetWindowClientRect (BYVAL hwnd AS HWND) AS RECT
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
A RECT structure with the retrieved coordinates of the window’s client area.
Returns the width of the client area of a window, in pixels.
FUNCTION AfxGetWindowClientWidth (BYVAL hwnd AS HWND) AS LONG
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
Returns the height of a window, in pixels.
FUNCTION AfxGetWindowHeight (BYVAL hwnd AS HWND) AS LONG
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
Returns the location of the top left corner of the window, in pixels. The location is relative to the upper-left corner of the client area in the parent window.
SUB AfxGetWindowLocation (BYVAL hwnd AS HWND, BYREF nLeft AS LONG, BYREF nTop AS LONG)
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| nLeft | Out. The horizontal location. |
| nTop | Out. The vertical location. |
Retrieves the dimensions of the bounding rectangle of the specified window. The dimensions are given in screen coordinates that are relative to the upper-left corner of the screen.
FUNCTION AfxGetWindowRect (BYVAL hwnd AS HWND) AS RECT
A RECT structure with the retrieved dimensions.
Gets the width and height of the specified window, in pixels.
FUNCTION AfxGetWindowSize (BYVAL hwnd AS HWND, BYVAL nWidth AS LONG, BYVAL nHeight AS LONG) AS BOOLEAN
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| nWidth | The width of the window. |
| nHeight | The height of the window. |
Gets the text of a window. This function can also be used to retrieve the text of buttons, edit and static controls.
FUNCTION AfxGetWindowText (BYVAL hwnd AS HWND) AS DWSTRING
The text of the window.
For an edit control, the text returned is the content of the edit control. For a combo box, the text is the content of the edit control (or static-text) portion of the combo box. For a button, the text is the button name. For other windows, the text is the window title. To retrieve the text of an item in a list box, an application can use the ListBox_GetText function.
Rich Edit: If the text to be copied exceeds 64K, use either the EM_STREAMOUT or EM_GETSELTEXT message.
This function uses the WM_GETTEXT message because GetWindowText cannot retrieve the text of a window in another application.
DIM dwsText AS DWSTRING = AfxGetWindowText(hwnd) MessageBoxW 0, dwsText, ““, MB_OK
Retrieves the length of the text of a window. This function can also be used to retrieve the length of the text of buttons, edit and static controls.
FUNCTION AfxGetWindowTextLength (BYVAL hwnd AS HWND) AS LONG
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
If the function succeeds, the return value is the length of the text in characters, not including the terminating null character.
If the function fails, the return value is zero.
For an edit control, the text returned is the content of the edit control. For a combo box, the text is the content of the edit control (or static-text) portion of the combo box. For a button, the text is the button name. For other windows, the text is the window title. To retrieve the text of an item in a list box, an application can use the ListBox_GetTextLength function.
AfxGetWindowTextLength sends a WM_GETTEXTLENGTH message. When the WM_GETTEXTLENGTH message is sent, the DefWindowProc function returns the length, in characters, of the text. Under certain conditions, the DefWindowProc function returns a value that is larger than the actual length of the text. This occurs with certain mixtures of ANSI and Unicode, and is due to the system allowing for the possible existence of double-byte character set (DBCS) characters within the text. The return value, however, will always be at least as large as the actual length of the text; you can thus always use it to guide buffer allocation. This behavior can occur when an application uses both ANSI functions and common dialogs, which use Unicode.
To obtain the exact length of the text, use the WM_GETTEXT, LB_GETTEXT, or CB_GETLBTEXT messages, or the GetWindowText function.
Sending a WM_GETTEXTLENGTH message to a non-text static control, such as a static bitmap or static icon control, does not return a string value. Instead, it returns zero.
Returns the width of a window, in pixels.
FUNCTION AfxGetWindowWidth (BYVAL hwnd AS HWND) AS LONG
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
Retrieves the height of the work area on the primary display monitor expressed in virtual screen coordinates. The work area is the portion of the screen not obscured by the system taskbar or by application desktop toolbars. To get the work area of a monitor other than the primary display monitor, call the GetMonitorInfo function.
FUNCTION AfxGetWorkAreaHeight () AS LONG
Retrieves the coordinates of the work area on the primary display monitor expressed in virtual screen coordinates. The work area is the portion of the screen not obscured by the system taskbar or by application desktop toolbars. To get the work area of a monitor other than the primary display monitor, call the GetMonitorInfo function.
FUNCTION AfxGetWorkAreaRect () AS RECT
A RECT structure with the retrieved coordinates.
Retrieves the width of the work area on the primary display monitor expressed in virtual screen coordinates. The work area is the portion of the screen not obscured by the system taskbar or by application desktop toolbars. To get the work area of a monitor other than the primary display monitor, call the GetMonitorInfo function.
FUNCTION AfxGetWorkAreaWidth () AS LONG
Redraws the non-client area of the specified window.
FUNCTION AfxRedrawNonClientArea (BYVAL hwnd AS HWND) AS BOOLEAN
If the function succeeds, the return value is TRUE.
If the function fails, the return value is FALSE. To get extended error information, call GetLastError.
Changes the position and dimensions of the specified window. For a top-level window, the position and dimensions are relative to the upper-left corner of the screen. For a child window, they are relative to the upper-left corner of the parent window’s client area. DPI aware versiomn of the API function MoveWindow.
PRIVATE FUNCTION AfxMoveWindowForDPI (BYVAL hwnd AS HWND, BYVAL x AS LONG, BYVAL y AS LONG, _
BYVAL nWidth AS LONG, BYVAL nHeight AS LONG, BYVAL bRepaint AS BOOLEAN = TRUE) AS BOOLEAN
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| x | The new position of the left side of the window. |
| y | The new position of the top side of the window. |
| nWidth | The new width of the window. |
| nHeight | The new height of the window. |
| bRepaint | Indicates whether the window is to be repainted. If this parameter is TRUE, the window receives a message. If the parameter is FALSE, no repainting of any kind occurs. This applies to the client area, the nonclient area (including the title bar and scroll bars), and any part of the parent window uncovered as a result of moving a child window. |
If the function succeeds, the return value is TRUE. If the function fails, the return value is FALSE. To get extended error information, call GetLastError.
If the bRepaint parameter is TRUE, the system sends the WM_PAINT message to the window procedure immediately after moving the window (that is, the MoveWindow function calls the UpdateWindow function). If bRepaint is FALSE, the application must explicitly invalidate or redraw any parts of the window and parent window that need redrawing.
MoveWindow sends the WM_WINDOWPOSCHANGING, WM_WINDOWPOSCHANGED, WM_MOVE, WM_SIZE, and WM_NCCALCSIZE messages to the window.
Redraws the specified window.
SUB AfxRedrawWindow (BYVAL hwnd AS HWND)
Adjusts the bounding rectangle of a window based on the desired size of the client area.
SUB AfxSetWindowClientSize (BYVAL hwnd AS HWND, BYVAL nWidth AS LONG, BYVAL nHeight AS LONG, _
BYVAL rxRatio AS SINGLE = 1, BYVAL ryRatio AS SINGLE = 1)
SUB AfxSetWindowClientSizeForDpi (BYVAL hwnd AS HWND, BYVAL nWidth AS LONG, BYVAL nHeight AS LONG)
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| nWidth | The new width of the client area of the window. |
| nHeight | The new height of the client area of the window. |
| rxRatio | Horizontal scaling ratio. |
| ryRatio | Vertical scaling ratio. |
AfxSetWindowClientSizeForDpi if DPI aware version of AfxSetWindowClientSizeFor.
Associates a new large icon with a window. The system displays the large icon in the ALT+TAB dialog box, and the small icon in the window caption.
FUNCTION AfxSetWindowIcon (BYVAL hwnd AS HWND, BYVAL nIconType AS LONG, BYVAL hIcon AS HICON) AS HICON
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| nIconType | The type of icon to be set. This parameter can be one of the
following values. ICON_BIG : Set the large icon for the window. ICON_SMALL : Set the small icon for the window. |
| hIcon | A handle to the new large icon. If this parameter is NULL, the icon is removed. |
The return value is a handle to the previous large or small icon, depending on the value of nIconType. It is NULL if the window previously had no icon of the type indicated by nIconType.
Sets the location of the top left corner of the window, in pixels.The location is relative to the upper-left corner of the client area in the parent window.
FUNCTION AfxSetWindowLocation (BYVAL hwnd AS HWND, BYVAL nLeft AS LONG, BYVAL nTop AS LONG) AS BOOLEAN
FUNCTION AfxSetWindowLocationForDpi (BYVAL hwnd AS HWND, BYVAL nLeft AS LONG, BYVAL nTop AS LONG) AS BOOLEAN
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| nLeft | The new position of the left side of the window, in client coordinates. |
| nTop | The new position of the top side of the window, in client coordinates. |
If the function succeeds, the return value is TRUE.
If the function fails, the return value is FALSE. To get extended error information, call GetLastError.
AfxSetWindowLocationForDpi is a DPI awre version of AfxSetWindowLocation.
Changes the size, position, and Z order of a child, pop-up, or top-level window. DPI aware version of the API function SetWindowPos.
PRIVATE FUNCTION AfxSetWindowPosForDPI (BYVAL hwnd AS HWND, BYVAL hWndInsertAfter AS HWND, _
BYVAL x AS LONG, BYVAL y AS LONG, BYVAL cx AS LONG, BYVAL cy AS LONG, _
BYVAL uFlags AS UINT = SWP_NOZORDER) AS BOOLEAN
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| hWndInsertAfter | A handle to the window to precede the positioned window in the Z order. |
| x | The new position of the left side of the window, in client coordinates. |
| y | The new position of the top side of the window, in client coordinates. |
| cx | The new width of the window, in pixels. |
| cy | The new height of the window, in pixels. |
| uFlags | The window sizing and positioning flags. This parameter can be a combination of the following values. See: SetWindowPos. |
Sets the size of the specified window, in pixels.
FUNCTION AfxSetWindowSize (BYVAL hwnd AS HWND, BYVAL nWidth AS LONG, BYVAL nHeight AS LONG) AS BOOLEAN
FUNCTION AfxSetWindowSizeForDpi (BYVAL hwnd AS HWND, BYVAL nWidth AS LONG, BYVAL nHeight AS LONG) AS BOOLEAN
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| nWidth | The new width of the window. |
| nHeight | The new height of the window. |
AfxSetWindowSizeForDpi is a DPI aware version of AfxSetWindowSize.
Sets the text of a window. This function can also be used to set the text of buttons, edit and static controls.
FUNCTION AfxSetWindowText (BYVAL hwnd AS HWND, BYVAL pwszText AS WSTRING PTR) AS BOOLEAN
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| pwszText | The text to set. |
If the function succeeds, the return value is TRUE.
If the function fails, the return value is FALSE.
Sets the specified window’s show state.
FUNCTION AfxShowWindowState (BYVAL hwnd AS HWND, BYVAL nShowState AS LONG) AS BOOLEAN
| Parameter | Description |
|---|---|
| hwnd | Handle to the window. |
| nShowState | Controls how the window is to be shown. This parameter is ignored the first time an application calls AfxShowWindowState, if the program that launched the application provides a STARTUPINFO structure. Otherwise, the first time AfxShowWindowState is called, the value should be the value obtained by the WinMain function in its nCmdShow parameter. In subsequent calls, this parameter can be one of the values listed below. |
| Value | Maning |
|---|---|
| SW_FORCEMINIMIZE | Minimizes a window, even if the thread that owns the window is not responding. This flag should only be used when minimizing windows from a different thread. |
| SW_HIDE | Hides the window and activates another window. |
| SW_MAXIMIZE | Maximizes the specified window. |
| SW_MINIMIZE | Minimizes the specified window and activates the next top-level window in the Z order. |
| SW_RESTORE | Activates and displays the window. If the window is minimized or maximized, the system restores it to its original size and position. An application should specify this flag when restoring a minimized window. |
| SW_SHOW | Activates the window and displays it in its current size and position. |
| SW_SHOWDEFAULT | Sets the show state based on the SW_ value specified in the STARTUPINFO structure passed to the CreateProcess function by the program that started the application. |
| SW_SHOWMAXIMIZED | Activates the window and displays it as a maximized window. |
| SW_SHOWMINIMIZED | Activates the window and displays it as a minimized window. |
| SW_SHOWMINNOACTIVE | Displays the window as a minimized window. This value is similar to SW_SHOWMINIMIZED, except the window is not activated. |
| SW_SHOWNA | Displays the window in its current size and position. This value is similar to SW_SHOW, except that the window is not activated. |
| SW_SHOWNOACTIVATE | Displays a window in its most recent size and position. This value is similar to SW_SHOWNORMAL, except that the window is not activated. |
| SW_SHOWNORMAL | Activates and displays a window. If the window is minimized or maximized, the system restores it to its original size and position. An application should specify this flag when displaying the window for the first time. |
If the window was previously visible, the return value is TRUE.
If the window was previously hidden, the return value is FALSE.
To perform certain special effects when showing or hiding a window, use AnimateWindow.
The first time an application calls AfxShowWindowState, it should use the WinMain function’s nCmdShow parameter as its nCmdShow parameter. Subsequent calls to AfxShowWindowState must use one of the values in the given list, instead of the one specified by the WinMain function’s nCmdShow parameter.
As noted in the discussion of the nCmdShow parameter, the nCmdShow value is ignored in the first call to AfxShowWindowState if the program that launched the application specifies startup information in the structure. In this case, AfxShowWindowState uses the information specified in the STARTUPINFO structure to show the window. On subsequent calls, the application must call AfxShowWindowState with nCmdShow set to SW_SHOWDEFAULT to use the startup information provided by the program that launched the application. This behavior is designed for the following situations:
Returns the Windows version.
FUNCTION AfxWindowsVersion () AS LONG
Platform 1:
400 Windows 95
410 Windows 98
490 Windows ME
Platform 2:
400 Windows NT
500 Windows 2000
501 Windows XP
502 Windows Server 2003
600 Windows Vista and Windows Server 2008
601 Windows 7
602 Windows 8
603 Windows 8.1
1000 Windows 10
Note 1: As Windows 95 and Windows NT return the same version number, we also need to call AfxGetWindowsPlatform to differentiate them.
Note 2: As Windows 10 and Windows 11 return the same version number, we also need to call AfxWindowsBuild to differentiate them. Windows 11 is Windows 10 build 21996 and higher.
AfxGetWindowsVersion
Returns the Windows major version.
FUNCTION AfxWindowsMajorVersion () AS LONG
AfxGetWindowsMajorVersion
Returns the Windows minor version.
FUNCTION AfxWindowsMinorVersion () AS LONG
AfxGetWindowsMinorVersion
Returns the full Windows version, including the build number, as a string.
FUNCTION AfxWindowsVersionStr () AS DWSTRING
AfxGetWindowsVersionStr
Returns the processor architecture of the operating system, e.g. “AMD64”.
FUNCTION AfxProcessorArchitecture () AS DWSTRING
Returns the number of processors.
FUNCTION AfxProcessorsCount () AS LONG
Returns the current committed memory limit for the system or the current process, whichever is smaller, in bytes.
FUNCTION AfxTotalPageFile () AS DWORDLONG
Returns maximum amount of memory the current process can commit, in bytes. This value is equal to or smaller than the system-wide available commit value.
FUNCTION AfxAvailablePageFile () AS DWORDLONG
Returns the Windows build number.
FUNCTION AfxWindowsBuild () AS LONG
AfxGetWindowsBuild
Returns the date in which Windows was installed, in Unix time.
FUNCTION AfxWindowsInstallDate () AS DWORD
AfxGetWindowsInstallDate
PRINT AfxUnixDateStr(AfxWindowsInstallDate, "dd-MM-yyyy")
PRINT AfxUnixTimeStr(AfxWindowsInstallDate, "hh':'mm':'ss")
Returns TRUE if Windows applications are using dark mode, or FALSE otherwise.
FUNCTION AfxAppsUseDarkMode () AS BOOLEAN
Returns TRUE if Windows is using dark mode, or FALSE otherwise.
FUNCTION AfxSystemUseDarkMode () AS BOOLEAN
Returns the Windows platform.
FUNCTION AfxWindowsPlatform () AS LONG
| Value | Description |
|---|---|
| 1 | Windows 95/98/ME |
| 2 | Windows NT/2000/XP/Server/Vista/Windows 7 |
AfxGetWindowsPlatform
Returns the Windows bitness (32 or 64 bit).
FUNCTION AfxWindowsBitness () AS LONG
Returns TRUE if the Windows Platform is NT; FALSE, otherwise.
FUNCTION AfxIsPlatformNT () AS BOOLEAN
Returns the Windows feature update versión, e.g. 22H2.
FUNCTION AfxWindowsFeatureUpdate () AS DWSTRING
Returns the version of CommCtl32.dll
#define AfxComCtlVersion AfxGetFileVersion("COMCTL32.DLL")
The version of CommCtl32.dll multiplied by 100, e.g. 582 for version 5.82.
Displays an application modal message box. Can be used with any string data type or literal.It is a quick shortcur for the MessageBoxW API function.
FUNCTION AfxMsg (BYREF wszText AS WSTRING, BYREF wszCaption AS WSTRING = "Message", _
BYVAL uType AS DWORD = 0) AS LONG
FUNCTION AfxMsg (BYVAL pwszText AS WSTRING PTR, BYREF wszCaption AS WSTRING = "Message", _
BYVAL uType AS DWORD = 0) AS LONG
FUNCTION AfxMsg (BYVAL hWin AS HWND, BYREF wszText AS WSTRING, BYREF wszCaption AS WSTRING = "Message", _
BYVAL uType AS DWORD = 0) AS LONG
FUNCTION AfxMsg (BYVAL hWin AS HWND, BYVAL pwszText AS WSTRING PTR, BYREF wszCaption AS WSTRING = "Message", _
BYVAL uType AS DWORD = 0) AS LONG
| Parameter | Description |
|---|---|
| wszText | Any string data type or a literal. |
| pwszText | Pointer to a WSTRING. |
| wszCaption | Optional. The message box caption. Default title is “Message”. |
| uType | Optional. For a list of available types, see the Microsoft documentation for the MessageBoxW function. The MB_APPLMODAL type is always added. |
Retrieves the path of the Windows directory. This path does not end with a backslash unless the Windows directory is the root directory. For example, if the Windows directory is named Windows on drive C, the path of the Windows directory retrieved by this function is C:. If the system was installed in the root directory of drive C, the path retrieved is C:\.
FUNCTION AfxGetWinDir () AS DWSTRING
Retrieves the localized description of the specified Windows error code.
FUNCTION AfxGetWinErrMsg (BYVAL dwError AS DWORD) AS DWSTRING
| Parameter | Description |
|---|---|
| dwError | The Windows error code. |
The localized description of the error code.
Retrieves the NetBIOS name of the local computer. This name is established at system startup, when the system reads it from the registry.
FUNCTION AfxGetComputerName () AS DWSTRING
The NetBIOS name of the local computer.
AfxComputerName
The behavior of this function can be affected if the local computer is a node in a cluster. For more information, see ResUtilGetEnvironmentWithNetName and UseNetworkName.
Retrieves the fully qualified DNS name that uniquely identifies the local computer. This name is a combination of the DNS host name and the DNS domain name, using the form HostName.DomainName. If the local computer is a node in a cluster, dwsBuffer receives the fully qualified DNS name of the cluster virtual server.
FUNCTION AfxGetComputerNameDnsFullyQualified () AS DWSTRING
AfxComputerNameDnsHostname
Retrieves the DNS host name of the local computer. If the local computer is a node in a cluster, dwsBuffer receives the DNS host name of the cluster virtual server.
FUNCTION AfxGetComputerNameDnsHostname () AS DWSTRING
AfxComputerNameDnsHostname
Retrieves the NetBIOS name of the local computer. If the local computer is a node in a cluster, dwsBuffer receives the NetBIOS name of the cluster virtual server.
FUNCTION AfxGetComputerNameNetBIOS () AS DWSTRING
AfxComputerNameNetBIOS
Retrieves the name of the user associated with the current thread.
FUNCTION AfxGetUserName () AS DWSTRING
AfxUserName
The name of the current user associated with the current thread.
If the current thread is impersonating another client, the AfxGetUserName function returns the user name of the client that the thread is impersonating.
Retrieves the name of the user associated with the current thread.
FUNCTION AfxGetUserDomain () AS DWSTRING
Retrieves the amount of RAM that is physically installed on the computer, in kilobytes.
FUNCTION AfxGetPhysicallyInstalledSystemMemory () AS ULONGLONG
AfxPhysicallyInstalledSystemMemory
Checks if the process is running with real administrative privileges.
FUNCTION AfxIsProcessElevated () AS BOOLEAN
Returns the amount of actual physical memory, in bytes.
FUNCTION AfxMemoryLoad () AS DWORD
Returns the amount of actual physical memory, in bytes.
FUNCTION AfxTotalPhysicalMemory () AS DWORDLONG
Returns the amount of physical memory currently available, in bytes. This is the amount of physical memory that can be immediately reused without having to write its contents to disk first. It is the sum of the size of the standby, free, and zero lists.
FUNCTION AfxTotalPhysicalMemory () AS DWORDLONG
Returns size of the user-mode portion of the virtual address space of the calling process, in bytes. This value depends on the type of process, the type of processor, and the configuration of the operating system. For example, this value is approximately 2 GB for most 32-bit processes on an x86 processor and approximately 3 GB for 32-bit processes that are large address aware running on a system with 4-gigabyte tuning enabled.
FUNCTION AfxTotalVirtualMemory () AS DWORDLONG
Returns amount of unreserved and uncommitted memory currently in the user-mode portion of the virtual address space of the calling process, in bytes.
FUNCTION AfxAvailableVirtualMemory () AS DWORDLONG
Retrieves the product type for the operating system on the local computer, and maps the type to the product types supported by the specified operating system.
FUNCTION AfxGetProductInfo () AS DWORD
Can be one of the following values (some products below may be out of support).
| Name | Value | Meaning |
|---|---|---|
| PRODUCT_BUSINESS | &h00000006 | Business |
| PRODUCT_BUSINESS_N | &h00000010 | Business N |
| PRODUCT_CLUSTER_SERVER | &h00000012 | HPC Edition |
| PRODUCT_CLUSTER_SERVER_V | &h00000040 | Server Hyper Core V |
| PRODUCT_CORE | &h00000065 | Windows 10 Home |
| PRODUCT_CORE_COUNTRYSPECIFIC | &h00000063 | Windows 10 Home China |
| PRODUCT_CORE_N | &h00000062 | Windows 10 Home N |
| PRODUCT_CORE_SINGLELANGUAGE | &h00000064 | Windows 10 Home Single Language |
| PRODUCT_DATACENTER_EVALUATION_SERVER | &h00000050 | Server Datacenter (evaluation installation) |
| PRODUCT_DATACENTER_A_SERVER_CORE | &h00000091 | Server Datacenter, Semi-Annual Channel (core installation) |
| PRODUCT_STANDARD_A_SERVER_CORE | &h00000092 | Server Standard, Semi-Annual Channel (core installation) |
| PRODUCT_DATACENTER_SERVER | &h00000008 | Server Datacenter (full installation. For Server Core installations of Windows Server 2012 and later, use the method, Determining whether Server Core is running.) |
| PRODUCT_DATACENTER_SERVER_CORE | &h0000000C | Server Datacenter (core installation, Windows Server 2008 R2 and earlier) |
| PRODUCT_DATACENTER_SERVER_CORE_V | &h00000027 | Server Datacenter without Hyper-V (core installation) |
| PRODUCT_DATACENTER_SERVER_V | &h00000025 | Server Datacenter without Hyper-V (full installation) |
| PRODUCT_EDUCATION | &h00000079 | Windows 10 Education |
| PRODUCT_EDUCATION_N | &h0000007A | Windows 10 Education N |
| PRODUCT_ENTERPRISE | &h00000004 | Windows 10 Enterprise |
| PRODUCT_ENTERPRISE_E | &h00000046 | Windows 10 Enterprise E |
| PRODUCT_ENTERPRISE_EVALUATION | &h00000048 | Windows 10 Enterprise Evaluation |
| PRODUCT_ENTERPRISE_N | &h00000018 | Windows 10 Enterprise N |
| PRODUCT_ENTERPRISE_N_EVALUATION | &h00000054 | Windows 10 Enterprise N Evaluation |
| PRODUCT_ENTERPRISE_S | &h0000007D | Windows 10 Enterprise 2015 LTSB |
| PRODUCT_ENTERPRISE_S_EVALUATION | &h00000081 | Windows 10 Enterprise 2015 LTSB Evaluation |
| PRODUCT_ENTERPRISE_S_N | &h0000007E | Windows 10 Enterprise 2015 LTSB N |
| PRODUCT_ENTERPRISE_S_N_EVALUATION | &h00000082 | Windows 10 Enterprise 2015 LTSB N Evaluation |
| PRODUCT_ENTERPRISE_SERVER | &h0000000A | Server Enterprise (full installation) |
| PRODUCT_ENTERPRISE_SERVER_CORE | &h0000000E | Server Enterprise (core installation) |
| PRODUCT_ENTERPRISE_SERVER_CORE_V | &h00000029 | Server Enterprise without Hyper-V (core installation) |
| PRODUCT_ENTERPRISE_SERVER_IA64 | &h0000000F | Server Enterprise for Itanium-based Systems |
| PRODUCT_ENTERPRISE_SERVER_V | &h00000026 | Server Enterprise without Hyper-V (full installation) |
| PRODUCT_ESSENTIALBUSINESS_SERVER_ADDL | &h0000003C | Windows Essential Server Solution Additional |
| PRODUCT_ESSENTIALBUSINESS_SERVER_ADDLSVC | &h0000003E | Windows Essential Server Solution Additional SVC |
| PRODUCT_ESSENTIALBUSINESS_SERVER_MGMT | &h0000003B | Windows Essential Server Solution Management |
| PRODUCT_ESSENTIALBUSINESS_SERVER_MGMTSVC | &h0000003D | Windows Essential Server Solution Management SVC |
| PRODUCT_HOME_BASIC | &h00000002 | Home Basic |
| PRODUCT_HOME_BASIC_E | &h00000043 | Not supported |
| PRODUCT_HOME_BASIC_N | &h00000005 | Home Basic N |
| PRODUCT_HOME_PREMIUM | &h00000003 | Home Premium |
| PRODUCT_HOME_PREMIUM_E | &h00000044 | Not supported |
| PRODUCT_HOME_PREMIUM_N | &h0000001A | Home Premium N |
| PRODUCT_HOME_PREMIUM_SERVER | &h00000022 | Windows Home Server 2011 |
| PRODUCT_HOME_SERVER | &h00000013 | Windows Storage Server 2008 R2 Essentials |
| PRODUCT_HYPERV | &h0000002A | Microsoft Hyper-V Server |
| PRODUCT_IOTENTERPRISE | &h000000BC | Windows IoT Enterprise |
| PRODUCT_IOTENTERPRISE_S | &h000000BF | Windows IoT Enterprise LTSC |
| PRODUCT_IOTUAP | &h0000007B | Windows 10 IoT Core |
| PRODUCT_IOTUAPCOMMERCIAL | &h00000083 | Windows 10 IoT Core Commercial |
| PRODUCT_MEDIUMBUSINESS_SERVER_MANAGEMENT | &h0000001E | Windows Essential Business Server Management Server |
| PRODUCT_MEDIUMBUSINESS_SERVER_MESSAGING | &h00000020 | Windows Essential Business Server Messaging Server |
| PRODUCT_MEDIUMBUSINESS_SERVER_SECURITY | &h0000001F | Windows Essential Business Server Security Server |
| PRODUCT_MOBILE_CORE | &h00000068 | Windows 10 Mobile |
| PRODUCT_MOBILE_ENTERPRISE | &h00000085 | Windows 10 Mobile Enterprise |
| PRODUCT_MULTIPOINT_PREMIUM_SERVER | &h0000004D | Windows MultiPoint Server Premium (full installation) |
| PRODUCT_MULTIPOINT_STANDARD_SERVER | &h0000004C | Windows MultiPoint Server Standard (full installation) |
| PRODUCT_PPI_PRO | &h00000077 | Windows 10 Team |
| PRODUCT_PRO_FOR_EDUCATION | &h000000A4 | Windows 10 Pro Education |
| PRODUCT_PRO_WORKSTATION | &h000000A1 | Windows 10 Pro for Workstations |
| PRODUCT_PRO_WORKSTATION_N | &h000000A2 | Windows 10 Pro for Workstations N |
| PRODUCT_PROFESSIONAL | &h00000030 | Windows 10 Pro |
| PRODUCT_PROFESSIONAL_E | &h00000045 | Not supported |
| PRODUCT_PROFESSIONAL_N | &h00000031 | Windows 10 Pro N |
| PRODUCT_PROFESSIONAL_WMC | &h00000067 | Professional with Media Center |
| PRODUCT_SB_SOLUTION_SERVER | &h00000032 | Windows Small Business Server 2011 Essentials |
| PRODUCT_SB_SOLUTION_SERVER_EM | &h00000036 | Server For SB Solutions EM |
| PRODUCT_SERVER_FOR_SB_SOLUTIONS | &h00000033 | Server For SB Solutions |
| PRODUCT_SERVER_FOR_SB_SOLUTIONS_EM | &h00000037 | Server For SB Solutions EM |
| PRODUCT_SERVER_FOR_SMALLBUSINESS | &h00000018 | Windows Server 2008 for Windows Essential Server Solutions |
| PRODUCT_SERVER_FOR_SMALLBUSINESS_V | &h00000023 | Windows Server 2008 without Hyper-V for Windows Essential Server Solutions |
| PRODUCT_SERVER_FOUNDATION | &h00000021 | Server Foundation |
| PRODUCT_SERVERRDSH | &h000000AF | Windows 10 Enterprise for Virtual Desktops |
| PRODUCT_SMALLBUSINESS_SERVER | &h00000009 | Windows Small Business Server |
| PRODUCT_SMALLBUSINESS_SERVER_PREMIUM | &h00000019 | Small Business Server Premium |
| PRODUCT_SMALLBUSINESS_SERVER_PREMIUM_CORE | &h0000003F | Small Business Server Premium (core installation) |
| PRODUCT_SOLUTION_EMBEDDEDSERVER | &h00000038 | Windows MultiPoint Server |
| PRODUCT_STANDARD_EVALUATION_SERVER | &h0000004F | Server Standard (evaluation installation) |
| PRODUCT_STANDARD_SERVER | &h00000007 | Server Standard (full installation. For Server Core installations of Windows Server 2012 and later, use the method, Determining whether Server Core is running.) |
| PRODUCT_STANDARD_SERVER_CORE | &h0000000D | Server Standard (core installation, Windows Server 2008 R2 and earlier) |
| PRODUCT_STANDARD_SERVER_CORE_V | &h00000028 | Server Standard without Hyper-V (core installation) |
| PRODUCT_STANDARD_SERVER_V | &h00000024 | Server Standard without Hyper-V |
| PRODUCT_STANDARD_SERVER_SOLUTIONS | &h00000034 | Server Solutions Premium |
| PRODUCT_STANDARD_SERVER_SOLUTIONS_CORE | &h00000035 | Server Solutions Premium (core installation) |
| PRODUCT_STARTER | &h0000000B | Starter |
| PRODUCT_STARTER_E | &h00000042 | Not supported |
| PRODUCT_STARTER_N | &h0000002F | Starter N |
| PRODUCT_STORAGE_ENTERPRISE_SERVER | &h00000017 | Storage Server Enterprise |
| PRODUCT_STORAGE_ENTERPRISE_SERVER_CORE | &h0000002E | Storage Server Enterprise (core installation) |
| PRODUCT_STORAGE_EXPRESS_SERVER | &h00000014 | Storage Server Express |
| PRODUCT_STORAGE_EXPRESS_SERVER_CORE | &h0000002B | Storage Server Express (core installation) |
| PRODUCT_STORAGE_STANDARD_EVALUATION_SERVER | &h00000060 | Storage Server Standard (evaluation installation) |
| PRODUCT_STORAGE_STANDARD_SERVER | &h00000015 | Storage Server Standard |
| PRODUCT_STORAGE_STANDARD_SERVER_CORE | &h0000002C | Storage Server Standard (core installation) |
| PRODUCT_STORAGE_WORKGROUP_EVALUATION_SERVER | &h0000005F | Storage Server Workgroup (evaluation installation) |
| PRODUCT_STORAGE_WORKGROUP_SERVER | &h00000016 | Storage Server Workgroup |
| PRODUCT_STORAGE_WORKGROUP_SERVER_CORE | &h0000002D | Storage Server Workgroup (core installation) |
| PRODUCT_ULTIMATE | &h00000001 | Ultimate |
| PRODUCT_ULTIMATE_E | &h00000047 | Not supported |
| PRODUCT_ULTIMATE_N | &h0000001C | Ultimate N |
| PRODUCT_UNDEFINED | &h00000000 | An unknown product |
| PRODUCT_WEB_SERVER | &h00000011 | Web Server (full installation) |
| PRODUCT_WEB_SERVER_CORE | &h0000001D | Web Server (core installation) |
Retrieves the MAC address of a machine’s Ethernet card.
FUNCTION AfxGetMACAddress () AS STRING
The MAC address in the following format: MM-MM-MM-SS-SS-SS. The leftmost 6 digits, called a “prefix”, is associated with the adapter manufacturer. The rightmost digits of a MAC address represent an identification number for the specific device.
This function only supports one NIC card on your PC.
Get the MAC address of the first valid physical adapter using GetAdaptersAddresses.
FUNCTION AfxGetMACAddress () AS STRING
The MAC address in the following format: MM-MM-MM-SS-SS-SS. The leftmost 6 digits, called a “prefix”, is associated with the adapter manufacturer. The rightmost digits of a MAC address represent an identification number for the specific device.
This is the Microsoft-recommended method.
Populates a dynamic array of STRINGs with all the real MAC addresses of the system.
FUNCTION AfxGetAllMACAddresses (macs() AS STRING) AS LONG
The number of elements in the array or -1 on failure.
DIM macs(ANY) AS STRING
DIM count AS LONG = AfxGetAllMACAddresses(macs())
FOR i AS LONG = LBOUND(macs) TO UBOUND(macs)
PRINT macs(i)
NEXT
Populates a dynamic array of STRINGs with all real MAC addresses (Ethernet/Wi-Fi).
FUNCTION AfxGetAllPhysicalMACAddresses (macs() AS STRING) AS LONG
The number of elements in the array or -1 on failure.
DIM macs(ANY) AS STRING
DIM count AS LONG = AfxGetAllMACAddresses(macs())
FOR i AS LONG = LBOUND(macs) TO UBOUND(macs)
PRINT macs(i)
NEXT
Retrieves the path of the default browser.
FUNCTION AfxGetDefaultBrowserPath () AS DWSTRING
The retrieved path or an empty string.
Retrieves the name of the default client mail application.
FUNCTION AfxGetDefaultMailClientName () AS DWSTRING
The retrieved name or an empty string.
Retrieves the path of the default client mail application.
FUNCTION AfxGetDefaultMailClientPath () AS DWSTRING
The retrieved path or an empty string.
Returns the Internet Explorer version installed.
FUNCTION AfxGetInternetExplorerVersion () AS SINGLE
The Internet Explorer version (major.minor).
Attempts to make a connection to the Internet.
FUNCTION AfxInternetAttemptConnect () AS DWORD
Returns ERROR_SUCCESS if successful, or a system error code otherwise.
This function allows an application to first attempt to connect before issuing any requests. A client program can use this to evoke the dial-up dialog box. If the attempt fails, the application should enter offline mode.
Like all other aspects of the WinINet API, this function cannot be safely called from within DllMain or the constructors and destructors of global objects.
IF AfxInternetAttemptConnect = ERROR_SUCCESS THEN ? "You can connect to the Internet"
Checks if a connection to the Internet can be established.
FUNCTION AfxInternetCheckConnection (BYVAL pwszUrl AS WSTRING PTR) AS BOOLEAN
| Parameter | Description |
|---|---|
| pwszUrl | Pointer to a null-terminated string that specifies the URL to use to check the connection. |
Returns TRUE if a connection is made successfully, or FALSE otherwise. Use GetLastError to retrieve the error code. ERROR_NOT_CONNECTED is returned by GetLastError if a connection cannot be made or if the sockets database is unconditionally offline.
InternetCheckConnection is deprecated. InternetCheckConnection does not work in environments that use a web proxy server to access the Internet. Depending on the environment, use NetworkInformation.GetInternetConnectionProfile or the NLM Interfaces to check for Internet access instead.
IF AfxInternetCheckConnection("https://www.freebasic.net/forum/viewforum.php?f=1") THEN ? "Connection succeeded!"
Canonicalizes a URL, which includes converting unsafe characters and spaces into escape sequences.
FUNCTION AfxInternetCanonicalizeUrl (BYVAL pwszUrl AS WSTRING PTR, BYVAL dwFlags AS DWORD = 0) AS DWSTRING
| Parameter | Description |
|---|---|
| pwszUrl | A pointer to the string that contains the URL to canonicalize. |
| dwFlags | Controls canonicalization. If no flags are specified, the function converts all unsafe characters and meta sequences (such as .,\ .., and …) to escape sequences. This parameter can be one of the following values. |
| Value | Meaning |
|---|---|
| ICU_BROWSER_MODE | Does not encode or decode characters after “#” or “?”, and does not remove trailing white space after “?”. If this value is not specified, the entire URL is encoded and trailing white space is removed. |
| ICU_DECODE | Converts all %XX sequences to characters, including escape sequences, before the URL is parsed. |
| ICU_ENCODE_PERCENT | Encodes any percent signs encountered. By default, percent signs are not encoded. This value is available in Microsoft Internet Explorer 5 and later. |
| ICU_ENCODE_SPACES_ONLY | Encodes spaces only. |
| ICU_NO_ENCODE | Does not convert unsafe characters to escape sequences. |
| ICU_NO_META | Does not remove meta sequences (such as “.” and “..”) from the URL. |
The canonicalized url on success or an empty string on failure.
PRINT AfxInternetCanonicalizeUrl("http://msdn2.microsoft.com/en-us/ library/")
Combines a base and relative URL into a single URL. The resultant URL is canonicalized.
FUNCTION AfxInternetCombineUrl (BYVAL pwszBaseUrl AS WSTRING PTR, BYVAL pwszRelativeUrl AS WSTRING PTR, _
BYVAL dwFlags AS DWORD = 0) AS DWSTRING
| Parameter | Description |
|---|---|
| pwszBaseUrl | Pointer to a null-terminated string that contains the base URL. |
| pwszRelativeUrl | Pointer to a null-terminated string that contains the relative URL. |
| dwFlags | Controls canonicalization. If no flags are specified, the function converts all unsafe characters and meta sequences (such as .,\ .., and …) to escape sequences. This parameter can be one of the following values. |
| Value | Meaning |
|---|---|
| ICU_BROWSER_MODE | Does not encode or decode characters after “#” or “?”, and does not remove trailing white space after “?”. If this value is not specified, the entire URL is encoded and trailing white space is removed. |
| ICU_DECODE | Converts all %XX sequences to characters, including escape sequences, before the URL is parsed. |
| ICU_ENCODE_PERCENT | Encodes any percent signs encountered. By default, percent signs are not encoded. This value is available in Microsoft Internet Explorer 5 and later. |
| ICU_ENCODE_SPACES_ONLY | Encodes spaces only. |
| ICU_NO_ENCODE | Does not convert unsafe characters to escape sequences. |
| ICU_NO_META | Does not remove meta sequences (such as “.” and “..”) from the URL. |
The canonicalized url on success or an empty string on failure.
PRINT AfxInternetCombineUrl (BYVAL pwszBaseUrl AS WSTRING PTR, BYVAL pwszRelativeUrl AS WSTRING PTR, _
BYVAL dwFlags AS DWORD = 0) AS DWSTRING
Retrieves the connected state of the local system.
FUNCTION AfxInternetGetConnectedState () AS BOOLEAN
Returns TRUE or FALSE.
Retrieves the connection description.
FUNCTION AfxInternetGetConnectionDescription () AS DWORD
Can be a combination of the following values.
| Name | Value | Meaning |
|---|---|---|
| INTERNET_CONNECTION_CONFIGURED | &h40 | Local system has a valid connection to the Internet, but it might or might not be currently connected. |
| INTERNET_CONNECTION_LAN | &h02 | Local system uses a local area network to connect to the Internet. |
| INTERNET_CONNECTION_MODEM | &h01 | Local system uses a modem to connect to the Internet. |
| INTERNET_CONNECTION_MODEM_BUSY | &h08 | No longer used. |
| INTERNET_CONNECTION_OFFLINE | &h20 | Local system is in offline mode. |
| INTERNET_CONNECTION_PROXY | &h04 | Local system uses a proxy server to connect to the Internet. |
Retrieves the connection name.
FUNCTION AfxInternetGetConnectionDescription () AS DWORD
Returns the connection name on success or an empty string on failure.
Converts from HiMetric to Pixels (horizontal resolution). Himetric is a scaling unit similar to twips used in computing. It is one thousandth of a centimeter and is independent of the screen resolution. HiMetric per inch = 2540; 1 inch = 2.54 mm.
SUB AfxHiMetricToPixelsX (BYVAL hm AS LONG) AS LONG
| Parameter | Description |
|---|---|
| hm | The size in HiMetric units. |
The size in pixels.
Converts from HiMetric to Pixels (vertical resolution). Himetric is a scaling unit similar to twips used in computing. It is one thousandth of a centimeter and is independent of the screen resolution. HiMetric per inch = 2540; 1 inch = 2.54 mm.
SUB AfxHiMetricToPixelsY (BYVAL hm AS LONG) AS LONG
| Parameter | Description |
|---|---|
| hm | The size in HiMetric units. |
The size in pixels.
Converts from Pixels to HiMetric (horizontal resolution). Himetric is a scaling unit similar to twips used in computing. It is one thousandth of a centimeter and is independent of the screen resolution. HiMetric per inch = 2540; 1 inch = 2.54 mm.
SUB AfxPixelsToHiMetricX (BYVAL cx AS LONG) AS LONG
| Parameter | Description |
|---|---|
| cx | The size in pixels. |
The size in HiMetric units.
Converts from Pixels to HiMetric (vertical resolution). Himetric is a scaling unit similar to twips used in computing. It is one thousandth of a centimeter and is independent of the screen resolution. HiMetric per inch = 2540; 1 inch = 2.54 mm.
SUB AfxPixelsToHiMetricY (BYVAL cx AS LONG) AS LONG
| Parameter | Description |
|---|---|
| cy | The size in pixels. |
The size in HiMetric units.
Converts pixels to points size (1/72 of an inch). Horizontal resolution.
SUB AfxPixelsToPointsX (BYVAL pix AS LONG) AS LONG
| Parameter | Description |
|---|---|
| pix | The number of pixels. |
The number of points.
Converts pixels to points size (1/72 of an inch). Vertical resolution.
SUB AfxPixelsToPointsY (BYVAL pix AS LONG) AS LONG
| Parameter | Description |
|---|---|
| pix | The number of pixels. |
The number of points.
Converts pixels to twips. Horizontal resolution.
FUNCTION AfxPixelsToTwipsX (BYVAL nPixels AS LONG) AS LONG
| Parameter | Description |
|---|---|
| nPixels | The number of pixels. |
The number of twips.
Converts pixels to twips. Vertical resolution.
FUNCTION AfxPixelsToTwipsY (BYVAL nPixels AS LONG) AS LONG
| Parameter | Description |
|---|---|
| nPixels | The number of pixels. |
The number of twips.
Converts point size to DIP (device independent pixel). DIP is defined as 1/96 of an inch and a point is 1/72 of an inch.
FUNCTION AfxPointSizeToDip (BYVAL ptsize AS SINGLE) AS SINGLE
| Parameter | Description |
|---|---|
| ptsize | The point size to convert. |
The number of DIP pixels.
Converts a point size (1/72 of an inch) to pixels. Horizontal resolution.
FUNCTION AfxPointsToPixelsX (BYVAL pts AS LONG) AS LONG
| Parameter | Description |
|---|---|
| pts | The number of points. |
The number of pixels.
Converts a point size (1/72 of an inch) to pixels. Vertical resolution.
FUNCTION AfxPointsToPixelsY (BYVAL pts AS LONG) AS LONG
| Parameter | Description |
|---|---|
| pts | The number of points. |
The number of pixels.
Returns the width of a pixel in twips (horizontal resolution). Pixel dimensions can vary between systems and may not always be square, so separate functions for pixel width and height are required.
FUNCTION AfxTwipsPerPixelX () AS LONG
The number of twips per pixel.
Returns the width of a pixel in twips (vertical resolution). Pixel dimensions can vary between systems and may not always be square, so separate functions for pixel width and height are required.
FUNCTION AfxTwipsPerPixelY () AS LONG
The number of twips per pixel.
Converts twips to pixels. Horizontal resolution.
FUNCTION AfxTwipsToPixelsX (BYVAL nTwips AS LONG) AS LONG
| Parameter | Description |
|---|---|
| nTwips | The number of twips. |
The number of pixels.
Converts twips to pixels. Vertical resolution.
FUNCTION AfxTwipsToPixelsY (BYVAL nTwips AS LONG) AS LONG
| Parameter | Description |
|---|---|
| nTwips | The number of twips. |
The number of pixels.
Loads a DIB in memory and returns a pointer to it.
FUNCTION AfxDibLoadImage (BYVAL pwszFileName AS WSTRING PTR) AS BITMAPFILEHEADER PTR
| Parameter | Description |
|---|---|
| pwszFileName | Path of the bitmap file. |
A pointer to the bitmap file header. You must release it with CoTaskMemFree when no longer needed.
Saves a DIB to a file.
FUNCTION AfxDibSaveImage (BYVAL pwszFileName AS WSTRING PTR, BYVAL pbmfh AS BITMAPFILEHEADER PTR) AS BOOLEAN
| Parameter | Description |
|---|---|
| pwszFileName | Path of the bitmap file. |
| pbmfh | Pointer to the bitmap file header. |
TRUE if the DIB has been saved successfully; FALSE otherwise.
Retrieves the AC power status.
FUNCTION AfxACLineStatus () AS UBYTE
This member can be one of the following values:
| Value | Description |
|---|---|
| 0 | Offline |
| 1 | Online |
| 255 | Unknown status |
Retrieves the battery charge status.
FUNCTION AfxBatteryChargeStatus () AS UBYTE
| Value | Description |
|---|---|
| 1 | High. The battery capacity is at more than 66 percent. |
| 2 | Low. The battery capacity is at less than 33 percent. |
| 4 | Critical. The battery capacity is at less than five percent. |
| 8 | Charging. |
| 128 | No system battery. |
| 255 | Unknown status. Unable to read the battery flag information. |
The value is zero if the battery is not being charged and the battery capacity is between low and high.
The percentage of full battery charge remaining.
FUNCTION AfxBatteryLifePercent () AS UBYTE
This member can be a value in the range 0 to 100, or 255 if status is unknown.
Retrieves the number of seconds of battery life remaining, or –1 if remaining seconds are unknown or if the device is connected to AC power.
FUNCTION AfxBatteryLifeTime () AS LONG
Retrieves the number of seconds of battery life when at full charge, or –1 if full battery lifetime is unknown or if the device is connected to AC power.
FUNCTION AfxBatteryFullLifeTime () AS LONG
The system is only capable of estimating BatteryFullLifeTime based on calculations on BatteryLifeTime and BatteryLifePercent. Without smart battery subsystems, this value may not be accurate enough to be useful.